linux进程监控:判断是否存在,是否僵死进程,进行重启和杀死重启

最近做了一个进程调度框架,为了确保进程正常运行,进行了轮训检测;在进程不存在的时候,自动重启,如果存在,判断是否僵死,如果僵死,就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

你可能感兴趣的:(Linux)