目的:linux 下服務器程序會由於各類緣由dump掉,就會影響用戶使用,這裏提供一個簡單的進程監控和重啓功能。linux
實現原理:由定時任務crontab調用腳本,腳本用ps檢查進程是否存在,若是不存在則重啓並寫入日誌。ubuntu
# crontab -e */5 * * * * /mnt/bindmonitor.sh
#! /bin/sh host_dir=`echo ~` # 當前用戶根目錄 proc_name="/home/wkubuntu/named/sbin/named" # 進程名 file_name="/mnt/bindmonitor.log" # 日誌文件 pid=0 proc_num() # 計算進程數 { num=`ps -ef | grep $proc_name | grep -v grep | wc -l` return $num } proc_id() # 進程號 { pid=`ps -ef | grep $proc_name | grep -v grep | awk '{print $2}'` } proc_num number=$? if [ $number -eq 0 ] # 判斷進程是否存在 then /home/wkubuntu/named/sbin/named -c /home/wkubuntu/named/etc/named.conf -n 1 & # 重啓進程的命令,請相應修改 proc_id # 獲取新進程號 echo ${pid}, `date` >> $file_name # 將新進程號和重啓時間記錄 fi
a. #killall -15 named服務器
b. 5分鐘後,cat /mnt/bindmonitor.log看看有無最新的記錄,進程號與# ps -ef |grep named 進程號對應。測試