linux監控某個進程的運行shell指令碼,linux監控shell指令碼
該指令碼實現了對指定進程名的進程進行每隔2的掃描監控,一旦發現進程不存在便重新啟動。
#!/bin/sh
a=10;
while [[ @a -gt 5 ]]; do
if test $(pgrep -f $1|wc -l) -eq 2;then
sh stop.sh
gnome-terminal -x sh start.sh &
fi;
sleep 2;
done;
總結:(1)&表示當前進程又啟動一個進程執行gnome-terminal命令;(2)linux下父進程掛掉,子進程不會掛,而是將子進程的父進程設為1(init進程);(3)查看後台運行進程的命令jobs -l;查看進程20197的父進程的方法 ps -ef|grep 20197。
我的問題:pgrep -f $1|wc -l 在sh中的運行情況和在終端下啟動並執行結果是不一樣的,為啥在sh中執行不存在時,是2?,歡迎評論討論~~
linux 編寫程式查看某個進程是否存在,不可以用shell指令碼
可以用管道啊什麼的,如果a.out是你寫的,在a.out裡建立個管道,當它啟動時,發個訊息,讓b.out接收這個管道的訊息,接收到了就說明a啟動了。如果a.out不是你寫的,那我就不會了,哈,希望幫到你。剛接觸LINUX
哪位大俠有linux下監控多個進程是否死掉如果死掉就kill掉重啟,沒有該進程的話也重啟的shell指令碼
我以監控一個進程:“vmstat”命令的進程為例子。
#!/bin/bash
PROSS=`ps -el | grep vmstat | awk '{ print $14 }'`
STAT=`ps -el | grep vmstat | awk '{ print $2 }'`
PID=`ps -el | grep vmstat | awk '{ print $4 }'`
if [ $PROSS ]
then
if [ $STAT = "Z" ]
then
echo "$PROSS has dead"
echo "Now, killing it"
kill -9 $PID
echo "Now, restart"
vmstat 2 5 >> /tmp/vmstat.txt &
else
echo "$PROSS is running healthy"
fi
else
echo "The programm has dropped"
echo "Now, restart"
vmstat 2 5 >> /tmp/vmstat.txt &
fi