process_monitor.zip
#!/bin/sh
# http://code.google.com/p/mooon # 進程監控腳本,當指定進程不存在時,執行重啟腳本將它拉起 # 特色: # 1.本監控腳本可重復執行,它會自動做互斥,保證總是只有一個監控腳本進程存在 # 2.互斥不僅依據監控腳本文件名,而且包含了它的命令行參數,只有整體相同時互斥才生效 # 3.對於被監控的進程,可以只指定進程名,也可以包含命令行參數 # 4.不管是監控腳本還是被監控進程,總是只針對屬於當前用戶下的進程 # 需要指定個數的命令行參數 # 參數1:被監控的進程名 # 參數2:重啟被監控進程的腳本 if test $# -ne 2; then printf "\033[1;33musage: $0 process_cmdline restart_script\033[m\n" exit 1 fi process_cmdline="$1" # 需要監控的進程名,或完整的命令行,也可以為部分命令行 restart_script="$2" # 用來重啟進程的腳本,要求具有可執行權限 monitor_interval=10 # 定時檢測時間間隔,單位為秒 cur_user=`whoami` # 執行本監控腳本的用戶名 # 取指定網卡上的IP地址 #eth=1&&netstat -ie|awk -F'[: ]' 'begin{found=0;} { if (match($0,"eth'"$eth"'")) found=1; else if ((1==found) && match($0,"eth")) found=0; if ((1==found) && match($0,"inet addr:") && match($0,"Bcast:")) print $13; }' # 下面這段腳本,用來阻止多個監控腳本進程出現 uid=`id -u $cur_user` self_name=`basename $0` self_cmdline="$0 $*" process_name=$(basename `echo "$process_cmdline"|cut -d" " -f1`) # 以死循環方式,定時檢測指定的進程是否存在 while true; do self_count=`ps -C $self_name h -o euser,args| awk 'BEGIN { num=0; } { if (($1==uid || $1==cur_user) && match($0, self_cmdline)) {++num;}} END { printf("%d",num); }' uid=$uid cur_user=$cur_user self_cmdline="$self_cmdline"` if test $self_count -gt 2; then # 如果監控腳本已經運行,則退出不重復運行 printf "\033[0;32;31m$0 is running[$self_count], current user is $cur_user.\033[m\n" exit fi # 檢查被監控的進程是否存在,如果不存在則重啟 process_count=`ps -C $process_name h -o euser,args| awk 'BEGIN { num=0; } { if (($1==uid || $1==cur_user) && match($0, process_cmdline)) {++num;}} END { printf("%d",num); }' uid=$uid cur_user=$cur_user process_cmdline="$process_cmdline"` if test $process_count -lt 1; then # 執行重啟腳本,要求這個腳本能夠將指定的進程拉起來 printf "\033[0;32;34mrestart \"$process_cmdline\"\033[m\n" sh -c "$restart_script" # 注意一定要以“sh -c”方式執行 fi sleep $monitor_interval done本文出自 “飛月” 博客,請務必保留此出處http://mooon.blog.51cto.com/1246491/958837