最近,自己业务进行上线,上线后,需要考虑的是对各种服务进行监控,包括(httpd服务,mysqld服务等),现在想以mysqld服务为例总结下那种方式的脚本最为专业和合理:

(1).根据mysql的端口号来监控mysql的服务。(常见于监控mysql的本地服务)

    比较常见的一个脚本:

1 netstat -natup|grep mysqld|awk -F'[ :]+' '{print $5}'

 上面是将mysqld的端口号进行了过滤,这个方法的缺点是:有可能是端口在,但是服务可能是不正常的。例如:系统负载很高,cpu的负载也很高,连接数满了,这个是其存在的问题之一。

(2).根据mysql的进程监控mysql的服务:

     比较常见的一个脚本:

1 ps -aux |grep mysqld |grep -v grep|wc -l

  这种方式的缺点也是和上面的一样:有可能是端口在,但是服务可能是不正常的。例如:系统负载很高,cpu的负载也很高,连接数满了,这个是其存在的问题之一。

(3). 通过mysql客户端的命令以及用账户连接mysql,然后根据确定返回的命令状态或者返回的内容来确定mysql是否正常(本地或者是远程的连接状态)。

比较常见的一个判断脚本(只是其中的一些个核心内容):

1 mysql -uroot -p1234 -e'select version();'>&/dev/null
2 echo $?

如果上面的$?是0 的话,说明是能够正常连接的,如果为1的话,则说明是连接失败的。

这种方式的缺点是,需要有mysql的连接客户端,要有数据的账号和密码,以及连接数据库主机的授权。

(4).通过php/java的方式直接连接mysql的方式来监控mysql的服务状态。

比较常见的一个脚本,也是比较简单的:

1 <?php
2 $conn = mysql_connect('root','1234','locahost',3306) or die('mysql coulc not connect'.mysql_error());
3 
4 ?>

这种方式是最接近用户的访问方式,效果是最好的,因为上面的这种方式尽管就算是端口存在,但是只要服务器的cpu负载很高,那用户的访问肯定是不正常的。

所以报警的最佳方式不是服务的报警是否开启了,而是网站的用户访问是否还是正常。这才是最佳的报警原则和方式。  我们应该从用户的角度出发考虑问题,而不是说从运维的角度来考虑问题。 所以应该在工作中使用这个方式。

(5).下面来看下Apache或者是nginx的监控脚本的一些常用的写法:

其实Apache的监控和mysql的监控本质上都是一样的,可以仿照上面的方法进行编写。

但是还是要介绍一个比较新的方式,使用nmap的方式来进行监测,服务的端口有没有打开,可以监控远端的服务器的端口有没有打开:

1 HttpPortNum=`namp localhost -p 80|grep open |wc -l`
2 if [ HttpPortNum -eq 1 ];then
3     echo "httpd is running!"
4 else
5     echo "httpd is not running!"
6     /data0/apache/bin/apachectl start &  
7 fi

(6).使用URL的方式来进行监控:

1 #!/bin/bash
2 wget -T 10 -q --spider http://10.210.66.81/ >&/dev/null
3 
4 if [ $? -eq 0 ];then
5     echo "httpd is running!"
6 else
7     echo "httpd is not running!"
8     /data0/http2/bin/apachectl  start &
9 fi

(7).使用http code的方式来进行判断:

1 #!/usr/bin/bash
2 httpCode=`curl -I -s http://10.210.66.81|grep 200|awk '{print $2}'`
3 
4 if [ "$httpCode" -eq 200 ];then
5    echo "apache is running!"
6 else
7     echo "apache is not running!"
8     /data0/apache/bin/apachectl start &
9 fi

 

posted on 2015-06-01 14:32  shangzekai  阅读(364)  评论(0编辑  收藏  举报