您的足迹:首页 > 运维技巧 >无人值守,检测程序正常运行,遇故障则重启服务

无人值守,检测程序正常运行,遇故障则重启服务

在某些情况下,如系统负载过大server无法申请到内存而挂掉、server底层发生段错误、server占用内存过大被内核Kill,或者被某些程序误杀。那server将无法提供服务,导致业务中断,公司收入出现损失。

有一个非常有效并且常用的方案是crontab重启监控。
原理是每1分钟执行一次shell脚本,检测server的进程是否存活,如果存在则跳过。如果发现主进程已经挂掉,则执行restart逻辑,先kill掉所有残留的子进程,然后重新启动Server。

 

如果在系统的crontab中加入:

* * * * * /data/script/check_server.sh
/data/script/check_server.sh:
#!/usr/bin/bash
cmd="/application/php/bin/php /data/www/filter/http_server.php"
count=`ps aux |grep "$cmd" | grep -v "grep" | wc -l`

echo $count
if [ $count -lt 1 ]; then
ps aux |grep "$cmd" | grep -v "grep"| awk '{print $2}'|xargs kill -9
sleep 2
$cmd
echo "restart "$(date +%Y-%m-%d_%H:%M:%S) >/data/log/restart.log
fi

 

本博客所有文章如无特别注明均为原创。作者:admin
版权所有:《电光石火》 => 无人值守,检测程序正常运行,遇故障则重启服务
本文地址:http://www.ilkhome.cn/?post=123
欢迎转载!复制或转载请以超链接形式注明,文章为 admin 原创,并注明原文地址 无人值守,检测程序正常运行,遇故障则重启服务,谢谢。

相关推荐

版权所有:《电光石火》 => 无人值守,检测程序正常运行,遇故障则重启服务
本文地址:http://www.ilkhome.cn/?post=123
欢迎转载!请注明,文章均为 《电光石火》 原创,并注明本文地址,谢谢。


发表评论

路人甲 表情
看不清楚?点图切换 Ctrl+Enter快速提交

网友评论(0)