原创:Apache之HTTP网站智能监控脚本

 本站原创 [基于 署名-非商业使用-相同方式分享 2.5 协议,转载须注明链接] 

本文提供的脚本已经被管理员用于Debian生产环境并运行正常 

在某些64位的Linux系统中,Apache进程可能存在内存泄露、CPU死锁等情况,导致httpd或php5-cgi进程占用100%的CPU,并且无法自动释放。这个脚本将直接监控Apache/网站/HTTP服务的可用性,并且根据情况自动采取不同的操作,如强行自动重启Apache、在重启Apache依然无法解决的情况下自动重启服务器等等。

完整脚本如下。如需复制,请使用右侧浮动工具栏的“复制”按钮。

01#!/bin/bash
02
03# 本脚本由VPS管理百科编写
04# 访问:http://WWW.BOOTF.COM 获取技术支持
05
06URL="http://127.0.0.1/"
07curlit()
08{
09curl --connect-timeout 15 --max-time20 --head--silent "$URL"grep'200'
10}
11
12doit()
13{
14if! curlit; then
15sleep20
16top-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
18sleep2
19/etc/init.d/apache2 start > /dev/null
20/etc/init.d/httpd start > /dev/null
21echo$(date"Apache Restart">> /var/log/apachemonitor.log
22sleep30
23if! curlit; then
24echo$(date"Failed! Now Reboot Computer!">> /var/log/apachemonitor.log
25reboot
26fi
27sleep180
28fi
29}
30
31sleep300
32whiletruedo
33doit > /dev/null
34sleep10
35done

功能解释:

脚本将在启动后等待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状态码,而不是监控内部进程,因此准确权威,能反映网站的实际状态。