偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

Linux中如何讓進(jìn)程在后臺運(yùn)行

系統(tǒng) Linux 系統(tǒng)運(yùn)維
SSH (指 SSH 客戶端)是一個用于訪問遠(yuǎn)程主機(jī)的程序,它使得用戶能夠 在遠(yuǎn)程主機(jī)上執(zhí)行命令。這是在登錄遠(yuǎn)程主機(jī)中的最受推崇的方法之一,因為其設(shè)計目的就是在非安全網(wǎng)絡(luò)環(huán)境上為兩臺非受信主機(jī)的通信提供安全加密。

一. nohup / setsid / &

使用場景:如果只是臨時有一個命令需要長時間運(yùn)行,什么方法能最簡便的保證它在后臺穩(wěn)定運(yùn)行呢?

我們的解決辦法就有兩種途徑:要么讓進(jìn)程忽略 HUP 信號,要么讓進(jìn)程運(yùn)行在新的會話里從而成為不屬于此終端的子進(jìn)程。

解決方法:

1.nohup

只需在要處理的命令前加上 nohup 即可,標(biāo)準(zhǔn)輸出和標(biāo)準(zhǔn)錯誤缺省會被重定向到 nohup.out 文件中。一般我們可在結(jié)尾加上"&"來將命令同時放入后臺運(yùn)行,也可用>filename 2>&1來更改缺省的重定向文件名。

  1. [root@pvcent107 ~]# nohup ping www.ibm.com & 
  2. [1] 3059 
  3. nohup: appending output to `nohup.out
  4. [root@pvcent107 ~]# ps -ef |grep 3059 
  5. root      3059   984  0 21:06 pts/3    00:00:00 ping www.ibm.com 
  6. root      3067   984  0 21:06 pts/3    00:00:00 grep 3059 
  7. [root@pvcent107 ~]# 

2. setsid

setsid 的使用也是非常方便的,也只需在要處理的命令前加上 setsid 即可。

  1. [root@pvcent107 ~]# setsid ping www.ibm.com 
  2. [root@pvcent107 ~]# ps -ef |grep www.ibm.com 
  3. root     31094     1  0 07:28 ?        00:00:00 ping www.ibm.com 
  4. root     31102 29217  0 07:29 pts/4    00:00:00 grep www.ibm.com 
  5. [root@pvcent107 ~]# 

上例中我們的進(jìn)程 ID(PID)為31094,而它的父 ID(PPID)為1(即為 init 進(jìn)程 ID),并不是當(dāng)前終端的進(jìn)程 ID。請將此例與nohup 例中的父 ID 做比較。

3. &

將一個或多個命名包含在“()”中就能讓這些命令在子 shell 中運(yùn)行中 當(dāng)我們將"&"也放入“()”內(nèi)之后,我們就會發(fā)現(xiàn)所提交的作業(yè)并不在作業(yè)列表中,也就是說,是無法通過jobs來查看的。

  1. [root@pvcent107 ~]# (ping www.ibm.com &) 
  2. [root@pvcent107 ~]# ps -ef |grep www.ibm.com 
  3. root     16270     1  0 14:13 pts/4    00:00:00 ping www.ibm.com 
  4. root     16278 15362  0 14:13 pts/4    00:00:00 grep www.ibm.com 
  5. [root@pvcent107 ~]# 

新提交的進(jìn)程的父 ID(PPID)為1(init 進(jìn)程的 PID),并不是當(dāng)前終端的進(jìn)程 ID。因此并不屬于當(dāng)前終端的子進(jìn)程,從而也就不會受到當(dāng)前終端的 HUP 信號的影響了。

二. disown

使用場景:如果事先在命令前加上 nohup 或者 setsid 就可以避免 HUP 信號的影響。但是如果我們未加任何處理就已經(jīng)提交了命令,該如何補(bǔ)救才能讓它避免 HUP 信號的影響呢?

解決方法:這時想加 nohup 或者 setsid 已經(jīng)為時已晚,只能通過作業(yè)調(diào)度和 disown 來解決這個問題了

  • 用disown -h jobspec來使某個作業(yè)忽略HUP信號。
  • 用disown -ah 來使所有的作業(yè)都忽略HUP信號。
  • 用disown -rh 來使正在運(yùn)行的作業(yè)忽略HUP信號。

當(dāng)使用過 disown 之后,會將把目標(biāo)作業(yè)從作業(yè)列表中移除,我們將不能再使用jobs來查看它,但是依然能夠用ps -ef查找到它。

disown 示例1(如果提交命令時已經(jīng)用“&”將命令放入后臺運(yùn)行,則可以直接使用“disown”)

  1. [root@pvcent107 build]# cp -r testLargeFile largeFile & 
  2. [1] 4825 
  3. [root@pvcent107 build]# jobs 
  4. [1]+  Running                 cp -i -r testLargeFile largeFile & 
  5. [root@pvcent107 build]# disown -h %1 
  6. [root@pvcent107 build]# ps -ef |grep largeFile 
  7. root      4825   968  1 09:46 pts/4    00:00:00 cp -i -r testLargeFile largeFile 
  8. root      4853   968  0 09:46 pts/4    00:00:00 grep largeFile 
  9. [root@pvcent107 build]# logout 

disown 示例2(如果提交命令時未使用“&”將命令放入后臺運(yùn)行,可使用 CTRL-z 和“bg”將其放入后臺,再使用“disown”)

  1. [root@pvcent107 build]# cp -r testLargeFile largeFile2 
  2.  
  3. [1]+  Stopped                 cp -i -r testLargeFile largeFile2 
  4. [root@pvcent107 build]# bg %1 
  5. [1]+ cp -i -r testLargeFile largeFile2 & 
  6. [root@pvcent107 build]# jobs 
  7. [1]+  Running                 cp -i -r testLargeFile largeFile2 & 
  8. [root@pvcent107 build]# disown -h %1 
  9. [root@pvcent107 build]# ps -ef |grep largeFile2 
  10. root      5790  5577  1 10:04 pts/3    00:00:00 cp -i -r testLargeFile largeFile2 
  11. root      5824  5577  0 10:05 pts/3    00:00:00 grep largeFile2 
  12. [root@pvcent107 build]# 

三: screen

使用場景: 我們已經(jīng)知道了如何讓進(jìn)程免受 HUP 信號的影響,但是如果有大量這種命令需要在穩(wěn)定的后臺里運(yùn)行,如何避免對每條命令都做這樣的操作呢?

解決方案: 此時最方便的方法就是 screen 了。簡單的說,screen 提供了 ANSI/VT100 的終端模擬器,使它能夠在一個真實終端下運(yùn)行多個全屏的偽終端。screen 的參數(shù)很多,具有很強(qiáng)大的功能,

  • 用screen -dmS (sessionName)來建立一個處于斷開模式下的會話(并指定其會話名)。
  • 用screen -list 來列出所有會話。
  • 用screen -r (sessionName)來重新連接指定會話。
  • 用快捷鍵CTRL-a d 來暫時斷開當(dāng)前會話。

screen實例

  1. [root@pvcent107 ~]# screen -dmS Urumchi 
  2. [root@pvcent107 ~]# screen -list 
  3. There is a screen on
  4.         12842.Urumchi   (Detached) 
  5. 1 Socket in /tmp/screens/S-root. 
  6.  
  7. [root@pvcent107 ~]# screen -r Urumchi 

當(dāng)我們用“-r”連接到 screen 會話后,我們就可以在這個偽終端里面為所欲為,再也不用擔(dān)心 HUP 信號會對我們的進(jìn)程造成影響,也不用給每個命令前都加上“nohup”或者“setsid”了。

未使用 screen 時新進(jìn)程的進(jìn)程樹

  1. [root@pvcent107 ~]# ping www.google.com & 
  2. [1] 9499 
  3. [root@pvcent107 ~]# pstree -H 9499 
  4. init─┬─Xvnc 
  5.      ├─acpid 
  6.      ├─atd 
  7.      ├─2*[sendmail]     
  8.      ├─sshd─┬─sshd───bash───pstree 
  9.      │       └─sshd───bash───ping 

未使用 screen 時我們所處的 bash 是 sshd 的子進(jìn)程,當(dāng) ssh 斷開連接時,HUP 信號自然會影響到它下面的所有子進(jìn)程(包括我們新建立的 ping 進(jìn)程)。

使用了 screen 后新進(jìn)程的進(jìn)程樹

  1. [root@pvcent107 ~]# screen -r Urumchi 
  2. [root@pvcent107 ~]# ping www.ibm.com & 
  3. [1] 9488 
  4. [root@pvcent107 ~]# pstree -H 9488 
  5. init─┬─Xvnc 
  6.      ├─acpid 
  7.      ├─atd 
  8.      ├─screen───bash───ping 
  9.      ├─2*[sendmail] 

 

而使用了 screen 后就不同了,此時 bash 是 screen 的子進(jìn)程,而 screen 是 init(PID為1)的子進(jìn)程。那么當(dāng) ssh 斷開連接時,HUP 信號自然不會影響到 screen 下面的子進(jìn)程了。

責(zé)任編輯:武曉燕 來源: segmentfault
相關(guān)推薦

2017-03-15 19:54:05

Linux進(jìn)程后臺

2021-06-10 09:56:09

Linux命令shell

2016-11-02 09:49:21

Linux命令進(jìn)程

2025-02-10 04:00:00

Linux進(jìn)程Python

2024-01-26 10:56:47

go程序進(jìn)程

2019-06-26 08:00:39

Docker容器運(yùn)行命令

2020-11-08 14:37:46

Python壓縮文件代碼

2011-01-26 13:26:32

Linux進(jìn)程

2010-03-31 14:36:50

Oracle進(jìn)程結(jié)構(gòu)

2011-03-03 17:07:58

Pure-FTPd

2020-10-10 11:02:09

Linux 系統(tǒng) 數(shù)據(jù)

2011-02-24 10:11:31

FireFTPFirefox

2010-03-08 18:07:02

Linux后臺運(yùn)行命令

2010-03-08 17:53:36

Linux后臺運(yùn)行命令

2010-03-09 08:54:29

Linux后臺運(yùn)行命令

2010-03-08 18:18:38

Linux后臺運(yùn)行命令

2010-03-09 09:40:02

Linux后臺運(yùn)行命令

2018-07-02 16:00:13

Windows 10Windows后臺進(jìn)程

2015-01-27 23:21:53

Linux終端

2022-11-09 11:01:11

Linux命令后臺
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號