怎麼在後臺執行shell指令碼
阿新 • • 發佈:2018-11-10
後臺執行指令碼
- 執行指令碼test.sh:
./test.sh
- 中斷指令碼test.sh:
ctrl+c
- 在1的基礎上將執行中的test.sh,切換到後臺並暫停:
ctrl+z
- 執行
ctrl+z
後,test.sh在後臺是暫停狀態(stopped),使用命令:bg number
讓其在後臺開始執行(“number”是使用jobs
命令查到的 [ ]中的數字,不是pid)
- 直接在後臺執行指令碼test.sh:
./test.sh &
- 檢視當前shell環境中已啟動的任務情況:
jobs
- 將test.sh切換到前臺執行:
fg %number
(”number”為使用jobs
- 中斷後臺執行的test.sh指令碼:先
fg %number
切換到前臺,再ctrl+c
;或是直接kill %number
以上兩種在後臺執行test.sh的方法,當遇到退出當前shell終端時,後臺執行的test.sh也就結束了。這是因為以上兩種方法使得test.sh在後臺執行時,執行test.sh程序的父程序是當前shell終端程序,關閉當前shell終端時,父程序退出,會發送hangup訊號給所有子程序,子程序收到hangup以後也會退出。所以要想退出當前shell終端時test.sh繼續執行,則需要使用nohup忽略hangup訊號。
- 不中斷的在後臺執行test.sh:
nohup ./test.sh &
(test.sh的列印資訊會輸出到當前目錄下的nohup.out中) - 使用
jobs
可看到test.sh處於running狀態 - 使用
ps -ef |grep test.sh
可檢視到正在執行的test.sh指令碼程序 - 退出當前shell終端,再重新開啟,使用
jobs
看不到正在執行的test.sh,但使用ps -ef
可以看到
在後臺不中斷的執行test.sh,可以使用nohup忽略hangup訊號,或者使用setsid將其父程序改為init程序(程序號為1)
- 不中斷的在後臺執行test.sh另一個命令
setsid ./test.sh &
- 使用
ps -ef |grep test.sh
可看到test.sh程序的父程序id為1
測試指令碼
#!/bin/bash
int=1
while(( $int<=100 ))
do
echo $int
let "int++"
sleep 1
done