最近做了一个进程调度框架,为了确保进程正常运行,进行了轮训检测;在进程不存在的时候,自动重启,如果存在,判断是否僵死,如果僵死,就kill掉,再自动重启;
直接上脚本:
轮询检测进程(cron)
创建/root/runcron 目录, (目录是自己随便建的)
在这个目录下存放要执行的shell脚本, 参考脚本在下边;记得设置脚本的可执行权限
chmod u+x filename
在 /etc/crontab 中添加自己的任务,/root/runcron 是自己创建的,
*/1 * * * * root run-parts /root/runcron
这样定时任务就自己执行了, 查看命令
tail -f /var/log/cron
日志会有执行的记录,如果没有执行, 就重新启动下crond服务,
/sbin/service crond reload ##--->> 重新加载
/sbin/service crond restart ## ---->重启服务
判断进程是否存在,从而重启或者杀死
##脚本
#!/bin/bash
#判断指定进程是否存在
result=`ps -ef | grep -w dbjob | grep -v grep | wc -l`
if [ $result -le 0 ]; then
#不存在, 重启
nohup java -Xms512m -Xmx1024m -jar /home/project/dbjob.jar &
else
#存在,判断状态
#取进程状态,用来判断是否僵死
val=`ps -aux | grep dbjob | grep -v grep | awk '{print $8}'`
if [ "$val" == "Z" ];then
# 取进程ID,用来kill掉进程
pid = `ps -aux | grep dbjob | grep -v grep | awk '{print $2}'`
kill -9 $pid
fi
fi