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  進程號

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM