linux 进程监控和自动重启的简单实现
目的:linux 下服务器程序会因为各种原因 dump 掉,就会影响用户使用,这里提供一个简单的进程监控和重启功能。
实现原理:由定时任务 crontab 调用脚本,脚本用 ps 检查进程是否存在,如果不存在则重启并写入日志。
- crontab 修改
# crontab -e
*/5 * * * * /mnt/bindmonitor.sh
- /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 进程号对应。