Apache之HTTP网站智能监控脚本
在某些64位的Linux系统中,Apache进程可能存在内存泄露、CPU死锁等情况,导致httpd或php5-cgi进程占用100%的CPU,并且无法自动释放。这个脚本将直接监控Apache/网站/HTTP服务的可用性,并且根据情况自动采取不同的操作,如强行自动重启Apache、在重启Apache依然无法解决的情况下自动重启服务器等等。完整脚本如下。如需复制,请使用右侧浮动工具栏的“复制”按钮。
平板视图打印?01#!/bin/bash0203# 本脚本由VPS管理百科编写04# 访问:http://WWW.BOOTF.COM 获取技术支持0506URL="http://127.0.0.1/"07curlit()08{09curl --connect-timeout 15 --max-time20 --head--silent "$URL"| grep'200'10}1112doit()13{14if! curlit; then15sleep2016top-n 1 -b >> /var/log/apachemonitor.log17/usr/bin/killall -9 apache2 && /usr/bin/killall -9 php5-cgi && /usr/bin/killall -9 httpd && /usr/bin/killall -9 http && /usr/bin/killall -9 apache && /usr/bin/killall -9 php-cgi > /dev/null18sleep219/etc/init.d/apache2 start > /dev/null20/etc/init.d/httpd start > /dev/null21echo$(date) "Apache Restart">> /var/log/apachemonitor.log22sleep3023if! curlit; then24echo$(date) "Failed! Now Reboot Computer!">> /var/log/apachemonitor.log25reboot26fi27sleep18028fi29}3031sleep30032whiletrue; do33doit > /dev/null34sleep1035done 功能解释:
脚本将在启动后等待5分钟(防止脚本已经启动了,但Apache还没启动完毕,造成误判),然后每隔10秒,对本地http://127.0.0.1进行测试,如果正常返回200代码,则不进行任何操作;如果超过15秒仍然没有响应,或相应错误代码,则:
1、将top命令所得结果保存至 /var/log/apachemonitor.log 文件,用于分析故障原因;
2、无条件kill掉所有的apache/apache2/httpd/http/php-cgi/php5-cgi进程,不管是否存在;
3、启动Apache(为了兼容性考虑,同时尝试启动/etc/init.d/下的httpd与apache2)
4、记录Apache Restart 与当前时间至 /var/log/apachemonitor.log 日志中;
5、等待30S,如果网站正常访问了,则不进行任何操作,开始下个循环检测;如果访问仍然不正常,则将“Failed”写入日志,并执行reboot重启Linux。
使用方法:
将此脚本加入到rc.local自动启动即可。
本脚本使用了curl来获取网站状态,因此需要预先在Linux中安装好curl(一般都有)。
优缺点:
如果Apache本身出严重错误了,可能导致服务器不停重启(当然你可以把重启的那行删掉)
采用curl直接获取HTTP状态码,而不是监控内部进程,因此准确权威,能反映网站的实际状态。
页:
[1]