首页 > 其他网络资源 > 自定义监控脚本监控Apache上http站点

自定义监控脚本监控Apache上http站点

五月 25th, 2015 关键字:

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

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

#!/bin/bash

# 本脚本由VPS管理百科编写
# 访问 http://www.cnyinxingshu.com/获取技术支持

URL="http://127.0.0.1/"
curlit()
{
curl --connect-timeout 15 --max-time 20 --head --silent "$URL" | grep '200'
}

doit()
{
if ! curlit; then
sleep 20
top -n 1 -b >> /var/log/apachemonitor.log
/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
sleep 2
/etc/init.d/apache2 start > /dev/null
/etc/init.d/httpd start > /dev/null
echo $(date) "Apache Restart" >> /var/log/apachemonitor.log
sleep 30
if ! curlit; then
echo $(date) "Failed! Now Reboot Computer!" >> /var/log/apachemonitor.log
reboot
fi
sleep 180
fi
}

sleep 300
while true; do
doit > /dev/null
sleep 10
done

功能解释:

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

固定链接: http://www.cnyinxingshu.com/262.html Godaddy优惠码
Comments are closed.