您的位置:首页 > 运维架构 > Shell

监控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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: