在某些64位的Linux系统中,Apache进程可能存在内存泄露、CPU死锁等情况,导致httpd或php5-cgi进程占用100%的CPU,并且无法自动释放。这个脚本将直接监控Apache/网站/HTTP服务的可用性,并且根据情况自动采取不同的操作,如强行自动重启Apache、在重启Apache依然无法解决的情况下自动重启服务器等等。
完整脚本如下。如需复制,请使用右侧浮动工具栏的“复制”按钮。
06 | URL= "http://127.0.0.1/" |
09 | curl --connect-timeout 15 --max- time 20 -- head --silent "$URL" | grep '200' |
16 | top -n 1 -b >> /var/log/apachemonitor.log |
17 | /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/null |
19 | /etc/init.d/apache2 start > /dev/null |
20 | /etc/init.d/httpd start > /dev/null |
21 | echo $( date ) "Apache Restart" >> /var/log/apachemonitor.log |
24 | echo $( date ) "Failed! Now Reboot Computer!" >> /var/log/apachemonitor.log |
功能解释:
脚本将在启动后等待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状态码,而不是监控内部进程,因此准确权威,能反映网站的实际状态。