nohup和&後臺運行,進程查看及終止

1.nohup

用途:不掛斷地運行命令。

語法:nohup Command [ Arg … ] [ & ]

  無論是否將 nohup 命令的輸出重定向到終端,輸出都將附加到當前目錄的 nohup.out 文件中。

  如果當前目錄的 nohup.out 文件不可寫,輸出重定向到 $HOME/nohup.out 文件中。

  如果沒有文件能創建或打開以用於追加,那麼 Command 參數指定的命令不可調用。

退出狀態:該命令返回下列出口值:   

  126 可以查找但不能調用 Command 參數指定的命令。   

  127 nohup 命令發生錯誤或不能查找由 Command 參數指定的命令。   

  否則,nohup 命令的退出狀態是 Command 參數指定命令的退出狀態。

2.&

用途:在後臺運行

一般兩個一起用

nohup command &

eg:

nohup /usr/local/node/bin/node /www/im/chat.js >> /usr/local/node/output.log 2>&1 &


進程號7585

查看運行的後臺進程

(1)jobs -l

jobs命令只看當前終端生效的,關閉終端後,在另一個終端jobs已經無法看到後臺跑得程序了,此時利用ps(進程查看命令)

(2)ps -ef 

ps -aux|grep chat.js


 a:顯示所有程序 

 u:以用戶爲主的格式來顯示 
 x:顯示所有程序,不以終端機來區分

注:

  用ps -def | grep查找進程很方便,最後一行總是會grep自己

  用grep -v參數可以將grep命令排除掉

ps -aux|grep chat.js| grep -v grep

  再用awk提取一下進程ID 

ps -aux|grep chat.js| grep -v grep | awk '{print $2}'


3.如果某個進程起不來,可能是某個端口被佔用

查看使用某端口的進程

lsof -i:8090

netstat -ap|grep 8090

查看到進程id之後,使用netstat命令查看其佔用的端口

netstat -nap|grep 7779

使用kill殺掉進城後再啓動

4.終止後臺運行的進程

kill -9  進程號



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章