监控Nginx服务的Shell脚本
2014-10-17 16:03
393 查看
Php代码
Nginx 虽然处理并发量比 apache 确实要强点,但它这种 php-cgi 模式不是太稳定,这点网上也有朋友总结了,我在实现项目中也感受到了。
我们一台支付机,偶尔会出现以下情况的:php-cgi 进程突然消失了,造成PHP脚本无法访问;更不可思议的是明明是php-cgi 打开有两个端口在监听的,莫名其秒的突然有一个php-cgi 的端口被关闭了,造成所有请求全积在一个端口上,
结果造成PHP脚本访问异常。
基本这种情况,我写了个监控shell脚本的解决方案,不管以上出现那种情况,都自动恢复Nginx的服务.该脚本在生产环境上运行正常:
#!/bin/bash
#
# filename: webservermonitor.sh
# 功能:监控 nginx 的 php-cgi 是否正常
# 作者:V哥
# 运行: webservermonitor.sh &
#
# php-cgi 监听的IP和端口
V_PHP_CGI_PORT="127.0.0.1:9000 127.0.0.1:9001"
# nginx重启的脚本
V_NGINX="/usr/local/nginx/sbin/restart.sh"
# 日志文件
V_LOG="/tmp/webservermonitor.log"
# 函数定义:重启nginx
function restart_nginx(){
echo "----- `date` -----" >> $V_LOG
echo "------------------" >> $V_LOG
echo "`ps aux |grep 'nginx'`" >> $V_LOG
echo "------------------" >> $V_LOG
echo "`ps aux |grep 'php-cgi'`" >> $V_LOG
echo "------------------" >> $V_LOG
echo "`netstat -nlpt | grep 'php-cgi'`" >> $V_LOG
echo "------------------" >> $V_LOG
$V_NGINX >> $V_LOG
}
# 循环执行,不采用 crontab ,国为 crontab 最小单位是分钟,时间太长了
while :
do
# 1:先检测 nginx 主进程是否存在
V_NGINX_NUM=`ps axu |grep 'nginx' |grep -v 'grep' |wc -l`
if [ $V_NGINX_NUM -lt 1 ];then
restart_nginx
continue
fi
# 2:再检查php-cgi是否有进程存在
V_PHP_CGI_NUM=`ps axu |grep 'php-cgi' |grep -v 'grep' |wc -l`
if [ $V_PHP_CGI_NUM -lt 1 ];then
restart_nginx
continue
fi
# 3:再判断端口是否正常
for PORT in $V_PHP_CGI_PORT
do
V_NUM=`eval "netstat -nlpt | grep '${PORT}' | wc -l"`
if [ $V_NUM -lt 1 ];then
restart_nginx
continue
fi
done
# 休眠
sleep 5
done
Nginx 虽然处理并发量比 apache 确实要强点,但它这种 php-cgi 模式不是太稳定,这点网上也有朋友总结了,我在实现项目中也感受到了。
我们一台支付机,偶尔会出现以下情况的:php-cgi 进程突然消失了,造成PHP脚本无法访问;更不可思议的是明明是php-cgi 打开有两个端口在监听的,莫名其秒的突然有一个php-cgi 的端口被关闭了,造成所有请求全积在一个端口上,
结果造成PHP脚本访问异常。
基本这种情况,我写了个监控shell脚本的解决方案,不管以上出现那种情况,都自动恢复Nginx的服务.该脚本在生产环境上运行正常:
#!/bin/bash
#
# filename: webservermonitor.sh
# 功能:监控 nginx 的 php-cgi 是否正常
# 作者:V哥
# 运行: webservermonitor.sh &
#
# php-cgi 监听的IP和端口
V_PHP_CGI_PORT="127.0.0.1:9000 127.0.0.1:9001"
# nginx重启的脚本
V_NGINX="/usr/local/nginx/sbin/restart.sh"
# 日志文件
V_LOG="/tmp/webservermonitor.log"
# 函数定义:重启nginx
function restart_nginx(){
echo "----- `date` -----" >> $V_LOG
echo "------------------" >> $V_LOG
echo "`ps aux |grep 'nginx'`" >> $V_LOG
echo "------------------" >> $V_LOG
echo "`ps aux |grep 'php-cgi'`" >> $V_LOG
echo "------------------" >> $V_LOG
echo "`netstat -nlpt | grep 'php-cgi'`" >> $V_LOG
echo "------------------" >> $V_LOG
$V_NGINX >> $V_LOG
}
# 循环执行,不采用 crontab ,国为 crontab 最小单位是分钟,时间太长了
while :
do
# 1:先检测 nginx 主进程是否存在
V_NGINX_NUM=`ps axu |grep 'nginx' |grep -v 'grep' |wc -l`
if [ $V_NGINX_NUM -lt 1 ];then
restart_nginx
continue
fi
# 2:再检查php-cgi是否有进程存在
V_PHP_CGI_NUM=`ps axu |grep 'php-cgi' |grep -v 'grep' |wc -l`
if [ $V_PHP_CGI_NUM -lt 1 ];then
restart_nginx
continue
fi
# 3:再判断端口是否正常
for PORT in $V_PHP_CGI_PORT
do
V_NUM=`eval "netstat -nlpt | grep '${PORT}' | wc -l"`
if [ $V_NUM -lt 1 ];then
restart_nginx
continue
fi
done
# 休眠
sleep 5
done
相关文章推荐
- linux运维学习shell脚本监控nginx服务
- nginx、tomcat、http服务shell监控脚本
- mysql和nginx服务是否正常监控脚本
- Zabbix+Shell脚本监控线上服务
- 如何通过shell脚本来检查或监控MYSQL数据库服务是否正常?
- shell脚本:监控MySQL服务是否正常
- 实战模拟监控MySQL服务shell脚本小结
- 自动监控apache服务状态并重启的shell脚本
- shell脚本:监控HTTP服务的状态(测试返回码) 推荐
- 监控tomcat服务,服务异常时自动重启shell脚本
- 实战模拟监控MySQL服务shell脚本小结
- shell脚本监控MySQL服务是否正常
- 实战模拟监控MySQL服务shell脚本小结
- Linux基础之-利用shell脚本实现自动监控系统服务
- shell脚本监控tomcat服务运行状态,服务关闭后进行重启
- 实战模拟监控MySQL服务shell脚本小结
- 【shell脚本】监控服务进程状态
- SHELL脚本实现服务宕机监控自动重启
- shell脚本:监控MySQL服务是否正常
- shell 代码 进程监控脚本,拉起core dump的服务器进程,以维持服务稳定