1. 查看後台運行的命令 、進程狀態、關閉前後台命令
有兩個命令可以來查看,ps 和 jobs。區別在於 jobs 只能查看當前終端後台執行的任務,換了終端就看不見了。而ps命令適用於查看瞬時進程的動態,可以看到別的終端的任務。
先後起了兩個後台運行的進程,使用jobs後都顯示出來了。 「+」代表最近的一個任務(當前任務),「-」代表之前的任務。
只有在當前終端命令行中敲下 nohup和& 時,jobs命令才能將它顯示出來。如果將他們寫到 .sh 腳本中,然後執行腳本,是顯示不出來的
比如執行下面這個腳本後,jobs顯示不出來:
這個是查看進程常用的命令,不多說了。
a: 顯示所有程序 u: 以用戶為主的格式來顯示 x: 顯示所有程序,不以終端機來區分
在linux系統中,ps(Process Status的縮寫)命令常常用來用來列出系統中當前運行的進程。ps命令列出的是當前那些進程的快照,就是執行ps命令的那個時刻的那些進程, 如果想要動態的顯示進程信息,就可以使用top命令。 要對進程進行監測和控制,首先必須要了解當前進程的情況,也就是需要查看當前進程,而 ps 命令就是最基本同時也是非常強大的進程查看命令。使用該命令可以確定有哪些進程正在運行和運行的狀態、進程是否結束、進程有沒有僵死、哪些進程佔用了過多的資源等等。總之大部分信息都是可以通過執行該命令得到的。
Linux上進程有5種狀態:
ps命令有很多參數,具體如下:
ps -ef 與 ps aux
Linux下顯示系統進程的命令ps,最常用的有ps -ef 和ps aux。這兩個到底有什麼區別呢?兩者沒太大差別,討論這個問題,要追溯到Unix系統中的兩種風格,System V風格和BSD 風格,ps aux最初用到Unix Style中,而ps -ef被用在System V Style中,兩者輸出略有不同。現在的大部分Linux系統都是可以同時使用這兩種方式的。
ps -ef 是用標準的格式顯示進程的、其格式如下:
ps aux 是用BSD的格式來顯示、其格式如下:
其中STAT狀態位常見的狀態字元有
D 無法中斷的休眠狀態(通常 IO 的進程);
R 正在運行可中在隊列中可過行的;
S 處於休眠狀態; [ 注意:在前台的進程狀態為s+,而在後台的sleep進程狀態都是s ]
T 停止或被追蹤;
W 進入內存交換 (從內核2.6開始無效);
X 死掉的進程 (基本很少見);
Z 僵屍進程;
< 優先順序高的進程
N 優先順序較低的進程
L 有些頁被鎖進內存;
s 進程的領導者(在它之下有子進程);
l 多線程,克隆線程(使用 CLONE_THREAD, 類似 NPTL pthreads);
+ 後面有加號說明進程是「位於在 前台 進程組」。也就是進程可以使用鍵盤輸出;
(1)通過jobs命令查看jobnum,然後執行 kill %jobnum
(2)通過ps命令查看進程號PID,然後執行 kill %PID
如果是前台進程的話,直接執行 Ctrl+c 就可以終止了
將後台中的命令調至前台繼續運行
如果後台中有多個命令,可以先用jobs查看jobnun,然後用 fg %jobnum 將選中的命令調出。
(2)Ctrl + z 命令
將一個正在前台執行的命令放到後台,並且處於暫停狀態
(3)bg命令
將一個在後台暫停的命令,變成在後台繼續執行
如果後台中有多個命令,可以先用jobs查看jobnum,然後用 bg %jobnum 將選中的命令調出繼續執行。
2. Linux進程後台運行的幾種方式
Ctrl+z/bg/nohup/setsid/&
在Linux中,如果要讓進程在後台運行,一般情況下,我們在命令後面加上&即可,實際上,這樣是將命令放入到一個作業隊列中了:
./rsync.sh jobs
但是如上方到後台執行的進程,其父進程還是當前終端shell的進程,而一旦父進程退出,則會發送hangup信號給所有子進程,子進程收到hangup以後也會退出。如果我們要在退出shell的時候繼續運行進程,則需要使用nohup忽略hangup信號,或者setsid將將父進程設為init進程(進程號為1):對於已經在前台執行的命令,也可以重新放到後台執行,首先按ctrl+z暫停已經運行的進程,然後使用bg命令將停止的作業放到後台運行:bg %1,放回前台運行:%1。
# nohup ./rsync.sh setsid ./rsync.sh &或
# (./rsync.sh &) ////在一個subshell中執行# ps -ef|grep rsync
nohup 的用途就是讓提交的命令忽略 hangup 信號,標准輸出和標准錯誤預設會被重定向到 nohup.out 文件中。。一般我們可在結尾加上」&」來將命令同時放入後台運行,也可用」 > log.out 2>&1」來更改預設的重定向文件名。
上面的試驗演示了使用nohup/setsid加上&使進程在後台運行,同時不受當前shell退出的影響。那麼對於已經在後台運行的進程,該怎麼辦呢?可以使用disown命令:
# jobs
# disown -h %1# ps -ef|grep rsync
效果與setid相同,但是disown後無法通過jobs命令查看了。
screen
還有一種更加強大的方式是使用screen,首先創建一個斷開模式的虛擬終端,然後用-r選項重新連接這個虛擬終端,在其中執行的任何命令,都能達到nohup的效果,這在有多個命令需要在後台連續執行的時候比較方便。
GNU Screen是一款由GNU計劃開發的用於命令行終端切換的自由軟體。用戶可以通過該軟體同時連接多個本地或遠程的命令行會話,並在其間自由切換,可以看作是窗口管理器的命令行界面版本。它提供了統一的管理多個會話的界面和相應的功能。
# yum install screen -y
常用screen參數:
# screen -S docker-d 新建一個名叫docker-d的session,並馬上進入
# screen -dmS docker-d 新建一個名叫docker-d的session,但暫不進入,可用於系統啟動腳本里
# screen -ls 列出當前所有session
# screen -r docker-d 恢復到zhouxiao這個session,前提是已經是斷開狀態(-d可以遠程斷開會話)
# screen -x docker-d 連接到離線模式的會話(多窗口同步演示)
# screen ./rsync.sh screen創建一個執行腳本的單窗口會話,可以attach進程ID
# screen -wipe 檢查目前所有的screen作業,並刪除已經無法使用的screen作業
正常情況下,當你退出一個窗口中最後一個程序(通常是bash)後,這個窗口就關閉了。另一個關閉窗口的方法是使用C-a k,這個快捷鍵殺死當前的窗口,同時也將殺死這個窗口中正在運行的進程。
在每個screen session 下,所有命令都以 ctrl+a(C-a) 開始。
C-a w 顯示所有窗口列表
C-a k 這個快捷鍵殺死當前的窗口,同時也將殺死這個窗口中正在運行的進程。
C-a d detach,暫時離開當前session
上面只是基本也是最常用的用法,更多請參考man screen或linux screen 命令詳解。需要了解的是,一個用戶創建的screen,其他用戶(甚至root)通過screen -ls是看不見的。另外,Ctrl+a在bash下是用來回到行開頭,不幸與上面的組合快捷鍵沖突。
3. 如何在linux伺服器後台運行某個進程在Xshell里需要輸入什麼指令
運行命令後面加 & 是後台運行,但啟動它的父進程如果退出,這個 & 方式運行的依然會退出。
我的建議是用 screen 。這樣會啟動一個 shell 「屏幕」可以隨時斷開後再另外一個地方重新恢復。
另外還一個方法是用 fg bg nohup 這一套命令也可以。不過具體怎麼用我沒研究,但控制不如 screen 方便。
其實你這個最好的辦法還是寫到伺服器的開機運行命令行裡面,方便很多啊。
另外……佔用 ssh 有什麼大問題么……
4. 如何用CMD命令終止和啟動進程
CMD命令終止和啟動進程的方法。
如下參考:
1.在電腦上按「win+R」打開操作,輸入CMD,點擊確定。