检测Nginx服务是否正常运行(详解)

大家好今天给大家带来shell脚本的一个实例(检测Nginx服务是否正常运行)

需求:检测Nginx服务是否正常的运行,如果不在运行那么就启动Nginx服务器,那么如果启动Nginx失败,那么通过邮件报警的方式通知我们;

一、分析

1:监测Nginx服务是否正在运行如下:

[root@yankerp ~]# netstat -anput | grep nginx
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      27228/nginx: master

使用以上这条命令能够很清楚的看到Nginx正在运行

2:启动Nginx服务器,我们可以通过它的绝对路径去启动Nginx 我的Nginx安装路径为:/usr/local/nginx其中/sbin/下就是Nginx的启动项;

/usr/local/nginx/sbin/nginx 

3:如果启动失败,那么就通过邮件报警的方式通知

怎么样可以判断Nginx启动失败,我们可以使用特殊的状态变量$? 如果/usr/local/nginx/sbin/nginx 这条命令运行之后如果启动失败那么它$?就会输出非0的数值表示失败,那么至于邮件报警的方式这里我采用了sendemail

 

二、编写脚本

开头注释:#!/bin/bash一句话代表着此脚本中的内容是通过bash解析器来运行的

编写脚本的规范 输入时间--创建者的信息--联系邮箱地址--以及版本等等。如下:

#!/bin/bash
#Date: 17:17 2018-03-04
#Author: yankai
#Email: [email protected]
#Function: Nginx monitoring
#Version: 3.1

2)定义变量

. /etc/init.d/functions   #加载函数库,后面会用到
RED_COLOR='\E[1;31m'	#定义颜色(红色变量)输出更美观
RES='\E[0m'				#同上
NGX=`netstat -anput | grep nginx | wc -l`   #定义检测Nginx是否运行变量 通过wc命令获取行号
DA=`date +%Y-%m-%d`   #标准的时间输出后面会用到

3)定义函数

接下来就开始写第一个函数了,首先我们写一个获取本机的URL看看是否能够成功http://localhost

function Nginx_URL(){   #定义了监测本地URL函数
wget --spider -q -o /dev/null --tries=1 -T 5 http://localhost  #安静的输出---/dev/null 这里的wget参数不解释
if [ "$?" -ne 0 ]	#如果以上wget获取本地的url不等于0 也就是不成功
   then  #那么
     action "Nginx pages cannot be obtained_$DA" /bin/false >> /var/log/nginx_url_error.log
     #输出一条NginxURL检测失败,那么后面调用DA时间变量输出到/var/log/nginx_url_error.log日志中
fi   #最后fi结束if语句
}

那么我们在这里想一个问题,那么如果wget获取不到本地的URL 意味着Nginx可能会宕机,那么我们继续写检测Nginx是否运行的函数

function main(){  #定义总函数
        Nginx_URL  #调用NGinxurl函数来测试nginx本地的url是否能够正常运行
        Nginx_server   #调用检测nginx函数 来测试nginx服务器是否正在运行
}
main    #最后结束main函数

function Nginx_server(){	#定义检测Nginx函数
if [ "$NGX" -ne 0 ]		#$NGX这个变量的运行结果不等于0 非0代表正在运行
   then	#那么
     echo -en "${RED_COLOR} Nginx is running!\n${RES}"	#就输出Nginx is running 信息;
   else		#否则启动NGINX
     /usr/local/nginx/sbin/nginx 
fi
        if [ "$?" -ne 0 ];then 注意:在这里需要提前安装好sendemail邮件报警 可以参考我之前的文章这里不在演示
           /usr/local/bin/sendEmail -f [email protected] -t [email protected] -s smtp.163.com -u "Nginx alarm" -o message-content-type=html -o message-charset-utf8 -xu yankerpcs -xp 123456yk -m "Nginx has serious downtime" &>/dev/null
        fi
}

 

最后我们定义了两个函数同时检测Nginx的状态情况,最后我们需要定义总函数来调用以上函数进行最后的测试

 

function main(){  #定义总函数
        Nginx_URL  #调用NGinxurl函数来测试nginx本地的url是否能够正常运行
        Nginx_server   #调用检测nginx函数 来测试nginx服务器是否正在运行
}
main    #最后结束main函数。

 

三、结尾:

经过了上面的几种操作,我们已经知道了Nginx的各种判断来确定Nginx的运行状况,同时我们也设置了邮件报警的机制来发送报警消息给运维人员。那么最后的脚本如下:

#!/bin/bash
#Date: 17:17 2018-03-04
#Author: yankai
#Email: [email protected]
#Function: Nginx monitoring
#Version: 3.1
. /etc/init.d/functions
RED_COLOR='\E[1;31m'
RES='\E[0m' 
NGX=`netstat -anput | grep nginx | wc -l`
DA=`date +%Y-%m-%d`

function Nginx_URL(){
wget --spider -q -o /dev/null --tries=1 -T 5 http://localhost
if [ "$?" -ne 0 ]
   then
     action "Nginx pages cannot be obtained_$DA" /bin/false >> /var/log/nginx_url_error.log
fi
}

function Nginx_server(){
if [ "$NGX" -ne 0 ]
   then
     echo -en "${RED_COLOR} Nginx is running!\n${RES}"
   else
     /usr/local/nginx/sbin/nginx 
fi
        if [ "$?" -ne 0 ];then
           /usr/local/bin/sendEmail -f [email protected] -t [email protected] -s smtp.163.com -u "Nginx alarm" -o message-content-type=html -o message-charset-utf8 -xu yankerpcs -xp 123456yk -m "Nginx has serious downtime" &>/dev/null
        fi
}

function main(){
        Nginx_URL
        Nginx_server
}
main

 

运行测试如下:

 

当我们Nginx正在运行的时候我们发现它输出了Nginx is running 说明我们定义函数生效了。

 

2:那我们把Nginx关闭在运行脚本测试如下:

 

3:模仿/usr/local/nginx/sbin/nginx启动出错 测试邮件是否发送.....

邮件查收:

检测Nginx服务是否正常运行(详解)_第1张图片

最后我们要把此脚本添加到计划任务运行,在这里不在做演示! 上面的Nginx启动报错大家可以自己想办法让它启动失败,这里不在做演示。

 

希望对您有所帮助,再见~

 

 

你可能感兴趣的:(Shell,Linux)