`

Linux服务器系统监控框架与MSN、E-mail、手机短信报警的实现

 
阅读更多

  最近,在我原有的“Linux服务器系统监控程序”基础上,完善了HTTP、TCP、MySQL主动监控与MSN、E-mail、手机短信报警。监控程序以shell和PHP程序编写,以下为主要框架与部分代码:

  一、系统监控接口程序(interface.php)具有的报警方式
  1、MSN实时报警
  ①、监控程序每次检测到故障存在、或者故障恢复,都会发送短消息到管理员的MSN。
 

  发送MSN短消息用了一个PHP类:sendMsg,使用该PHP类发消息,必须将发送、接收双方的MSN加为联系人,发送中文时,先用iconv将字符集转为UTF-8:

引用
$sendMsg->sendMessage(iconv("GBK", "UTF-8", $message), 'Times New Roman', '008000');




  2、手机短信报警
  ①、工作日早上10点之前,晚上6点之后,以及周六、周日,监控程序检测到故障,会调用手机短信接口,发送短信给管理员的手机。
  ②、如果监控程序多次检测到同一台服务器的同一类故障,只会在第一次检测到故障时发送一条“故障报警”短信。服务器故障恢复后,监控程序会再发送一条“故障恢复”短信。

  如果没有手机短信网关接口,可以试试中国移动通信的www.139.com邮箱,具有免费的邮件到达手机短信通知功能,可以将收到的邮件标题以短信的形式发送到手机上。



  3、电子邮件报警
  ①、如果监控程序多次检测到同一台服务器的同一类故障,只会在第一次检测到故障时发送一封“故障报警”邮件。服务器故障恢复后,监控程序会再发送一封“故障恢复”邮件。

  系统监控接口程序interface.php(核心部分,仅提供部分代码):
  1. <?php   
  2. //HTTP服务器监控   
  3. if (htmlspecialchars($_POST["menu"]) == "http")      
  4. {      
  5.     $date = htmlspecialchars($_POST["date"]);      
  6.     $ip = htmlspecialchars($_POST["ip"]);   
  7.     $port = htmlspecialchars($_POST["port"]);   
  8.     $status = htmlspecialchars($_POST["status"]);//状态,0表示无法访问,1表示正常,2表示无法访问但能ping通   
  9.     //...下一步处理(省略)...     
  10. }   
  11.   
  12. //TCP服务器监控   
  13. if (htmlspecialchars($_POST["menu"]) == "tcp")      
  14. {      
  15.     $date = htmlspecialchars($_POST["date"]);      
  16.     $ip = htmlspecialchars($_POST["ip"]);   
  17.     $port = htmlspecialchars($_POST["port"]);   
  18.     $status = htmlspecialchars($_POST["status"]);//状态,0表示无法访问,1表示正常,2表示无法访问但能ping通   
  19.     //...下一步处理(省略)...   
  20. }   
  21.   
  22. //MySQL服务器监控   
  23. if (htmlspecialchars($_POST["menu"]) == "mysql")      
  24. {      
  25.     $date = htmlspecialchars($_POST["date"]);      
  26.     $ip = htmlspecialchars($_POST["ip"]);   
  27.     $port = htmlspecialchars($_POST["port"]);   
  28.     $abstract = htmlspecialchars($_POST["abstract"]);//故障摘要(必须为全角)   
  29.     $info = htmlspecialchars($_POST["info"]);//故障详细描述   
  30.     $failback = htmlspecialchars($_POST["failback"]);//如果服务器存活,此处接收的值为active   
  31.     //...下一步处理(省略)...   
  32. }   
  33. ?>  


  二、主动探测监控(“监控机”主动探测“被监控机”)
  1、HTTP服务器监控
  脚本:/data0/monitor/http.sh
引用
#!/bin/sh
LANG=C

#被监控服务器、端口列表
server_all_list=(\
192.168.1.1:80 \
192.168.1.2:80 \
192.168.1.3:80 \
)

date=$(date -d "today" +"%Y-%m-%d_%H:%M:%S")

#采用HTTP POST方式发送检测信息给接口程序interface.php,接口程序负责分析信息,决定是否发送报警MSN消息、手机短信、电子邮件。
send_msg_to_interface()
{
   /usr/bin/curl -m 600 -d menu=http -d date=$date -d ip=$server_ip -d port=$server_port -d status=$status http://127.0.0.1:8888/interface.php
}

server_all_len=${#server_all_list[*]}
i=0
while  [ $i -lt $server_all_len ]
do
   server_ip=$(echo ${server_all_list[$i]} | awk -F ':' '{print $1}')
   server_port=$(echo ${server_all_list[$i]} | awk -F ':' '{print $2}')
   if curl -m 10 -G http://${server_all_list[$i]}/ > /dev/null 2>&1
   then
     #status:    0,http down    1,http ok    2,http down but ping ok
     status=1
           echo "服务器${server_ip},端口${server_port}能够正常访问!"
   else
       if curl -m 30 -G http://${server_all_list[$i]}/ > /dev/null 2>&1
       then
           status=1
           echo "服务器${server_ip},端口${server_port}能够正常访问!"
       else
           if ping -c 1 $server_ip > /dev/null 2>&1
           then
               status=2
               echo "服务器${server_ip},端口${server_port}无法访问,但是能够Ping通!"
           else
               status=0
               echo "服务器${server_ip},端口${server_port}无法访问,并且无法Ping通!"
           fi
       fi
   fi
 send_msg_to_interface
   let i++
done



  2、TCP服务器监控
  脚本:/data0/monitor/tcp.sh
引用
#!/bin/sh
LANG=C

#被监控服务器、端口列表
server_all_list=(\
192.168.1.4:11211 \
192.168.1.5:11211 \
192.168.1.6:25 \
192.168.1.7:25 \
)

date=$(date -d "today" +"%Y-%m-%d_%H:%M:%S")

#采用HTTP POST方式发送检测信息给接口程序interface.php,接口程序负责分析信息,决定是否发送报警MSN消息、手机短信、电子邮件。
send_msg_to_interface()
{
   /usr/bin/curl -m 600 -d menu=tcp -d date=$date -d ip=$server_ip -d port=$server_port -d status=$status http://127.0.0.1:8888/interface.php
}

server_all_len=${#server_all_list[*]}
i=0
while  [ $i -lt $server_all_len ]
do
   server_ip=$(echo ${server_all_list[$i]} | awk -F ':' '{print $1}')
   server_port=$(echo ${server_all_list[$i]} | awk -F ':' '{print $2}')
   if nc -vv -z -w 3 $server_ip $server_port > /dev/null 2>&1
   then
       #status:    0,http down    1,http ok    2,http down but ping ok
       status=1
       echo "服务器${server_ip},端口${server_port}能够正常访问!"
   else
       if nc -vv -z -w 10 $server_ip $server_port > /dev/null 2>&1
       then
           status=1
           echo "服务器${server_ip},端口${server_port}能够正常访问!"
       else
           if ping -c 1 $server_ip > /dev/null 2>&1
           then
               status=2
               echo "服务器${server_ip},端口${server_port}无法访问,但是能够Ping通!"
           else
               status=0
               echo "服务器${server_ip},端口${server_port}无法访问,并且无法Ping通!"
           fi
       fi
   fi
   send_msg_to_interface
   let i++
done



  3、MySQL服务器监控
  ①、MySQL是否能够连接
  ②、MySQL是否发生表损坏等错误
  ③、MySQL活动连接数是否过多
  ④、MySQL从库是否同步正常
  ⑤、MySQL从库同步延迟时间是否过大
  脚本:/data0/monitor/mysql.php
  1. <?php   
  2. //$server_list[]="服务器地址:端口:帐号:密码";   
  3. $server_list[]="192.168.1.11:3306:root:password";   
  4. $server_list[]="192.168.1.12:3306:root:password";   
  5. $server_list[]="192.168.1.13:3306:root:password";   
  6.   
  7. $database="mysql";   
  8.   
  9. $curl = new Curl_Class();    
  10.   
  11. foreach ($server_list as $server) {   
  12.     $status=1;//初始化,正常状态   
  13.   unset($data);   
  14.     $data["menu"] = "mysql";   
  15.   $data["info"] = "";   
  16.     list($data["ip"], $data["port"], $username$password) = explode(":"$server);   
  17.   
  18.     $connect = @mysql_connect($data["ip"].":".$data["port"], $username$password);   
  19.     if(! $connect)   
  20.     {   
  21.         $status=0;   
  22.         $data["info"] = $data["info"] . "无法连接MySQL服务器\r\n";   
  23.     }   
  24.      
  25.     $select = @mysql_select_db($database$connect);   
  26.     $result = @mysql_query("show slave status");   
  27.     $rs_slave = @mysql_fetch_array($result);   
  28.     $result = @mysql_query("show global status like 'Threads_running'");   
  29.     $rs_threads = @mysql_fetch_array($result);   
  30.     if($rs_slave["Slave_SQL_Running"] == "No")   
  31.     {   
  32.         $status=0;//故障状态   
  33.         $data["abstract"] = "从库不同步";   
  34.         $data["info"] = $data["info"] . "Slave_SQL_Running = No\r\n";     
  35.     }   
  36.     if($rs_slave["Slave_IO_Running"] == "No")   
  37.     {   
  38.         $status=0;   
  39.         $data["abstract"] = "从库不同步";   
  40.         $data["info"] = $data["info"] . "Slave_IO_Running = No\r\n";     
  41.     }   
  42.     if($rs_slave["Last_Error"] != "")   
  43.     {   
  44.         $status=0;   
  45.         $data["abstract"] = "从库同步出错";   
  46.         $data["info"] = $data["info"] . "Last_Error = ".substr($rs_slave["Last_Error"], 0, 40)."\r\n";   
  47.     }   
  48.     if($rs_slave["Seconds_Behind_Master"] > 180)   
  49.     {   
  50.         $status=0;   
  51.         $data["abstract"] = "从库同步延迟时间高达".$rs_slave["Seconds_Behind_Master"]."秒";   
  52.         $data["info"] = $data["info"] . "Seconds_Behind_Master = ".$rs_slave["Seconds_Behind_Master"]."\r\n";   
  53.     }   
  54.     if($rs_threads["Value"] > 60)   
  55.     {   
  56.         $status=0;   
  57.         $data["abstract"] = "活动连接数多达".$rs_threads["Value"];   
  58.         $data["info"] = $data["info"] . "Threads_running = ".$rs_threads["Value"]."\r\n";   
  59.     }   
  60.   
  61.     $data["date"] = date("Y-m-d_H:i:s");   
  62.     if($status == 0)   
  63.     {   
  64.         $post = @$curl->post("http://127.0.0.1:8888/interface.php"$data);   
  65.         echo "MySQL服务器“".$data["ip"].":".$data["port"]."”发生故障!\n";   
  66.         print_r($post);         
  67.     }   
  68.     else  
  69.     {   
  70.         $data["failback"] = "active";//服务器正常,发送通知信息   
  71.         $post = @$curl->post("http://127.0.0.1:8888/interface.php"$data);   
  72.         echo "MySQL服务器“".$data["ip"].":".$data["port"]."”运行正常!\n";   
  73.         print_r($post);   
  74.     }   
  75. }   
  76.   
  77. /**  
  78. *********************************************************************  
  79. * Curl_Class :curl 类  
  80. *********************************************************************/  
  81. class Curl_Class   
  82. {   
  83.     function Curl_Class()   
  84.     {   
  85.         return true;   
  86.     }   
  87.   
  88.     function execute($method$url$fields = ''$userAgent = ''$httpHeaders = '',   
  89.         $username = ''$password = '')   
  90.     {   
  91.         $ch = Curl_Class::create();   
  92.         if (false === $ch)   
  93.         {   
  94.             return false;   
  95.         }   
  96.   
  97.         if (is_string($url) && strlen($url))   
  98.         {   
  99.             $ret = curl_setopt($ch, CURLOPT_URL, $url);   
  100.         }   
  101.         else  
  102.         {   
  103.             return false;   
  104.         }   
  105.         //是否显示头部信息   
  106.         curl_setopt($ch, CURLOPT_HEADER, false);   
  107.         //   
  108.         curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);   
  109.   
  110.         if ($username != '')   
  111.         {   
  112.             curl_setopt($ch, CURLOPT_USERPWD, $username . ':' . $password);   
  113.         }   
  114.   
  115.         $method = strtolower($method);   
  116.         if ('post' == $method)   
  117.         {   
  118.             curl_setopt($ch, CURLOPT_POST, true);   
  119.             if (is_array($fields))   
  120.             {   
  121.                 $sets = array();   
  122.                 foreach ($fields as $key => $val)   
  123.                 {   
  124.                     $sets[] = $key . '=' . urlencode($val);   
  125.                 }   
  126.                 $fields = implode('&'$sets);   
  127.             }   
  128.             curl_setopt($ch, CURLOPT_POSTFIELDS, $fields);   
  129.         }   
  130.         else  
  131.             if ('put' == $method)   
  132.             {   
  133.                 curl_setopt($ch, CURLOPT_PUT, true);   
  134.             }   
  135.   
  136.         //curl_setopt($ch, CURLOPT_PROGRESS, true);   
  137.         //curl_setopt($ch, CURLOPT_VERBOSE, true);   
  138.         //curl_setopt($ch, CURLOPT_MUTE, false);   
  139.         curl_setopt($ch, CURLOPT_TIMEOUT, 600);   
  140.   
  141.         if (strlen($userAgent))   
  142.         {   
  143.             curl_setopt($ch, CURLOPT_USERAGENT, $userAgent);   
  144.         }   
  145.   
  146.         if (is_array($httpHeaders))   
  147.         {   
  148.             curl_setopt($ch, CURLOPT_HTTPHEADER, $httpHeaders);   
  149.         }   
  150.   
  151.         $ret = curl_exec($ch);   
  152.   
  153.         if (curl_errno($ch))   
  154.         {   
  155.             curl_close($ch);   
  156.             return array(curl_error($ch), curl_errno($ch));   
  157.         }   
  158.         else  
  159.         {   
  160.             curl_close($ch);   
  161.             if (!is_string($ret) || !strlen($ret))   
  162.             {   
  163.                 return false;   
  164.             }   
  165.             return $ret;   
  166.         }   
  167.     }   
  168.   
  169.     function post($url$fields$userAgent = ''$httpHeaders = ''$username = '',   
  170.         $password = '')   
  171.     {   
  172.         $ret = Curl_Class::execute('POST'$url$fields$userAgent$httpHeaders$username,   
  173.             $password);   
  174.         if (false === $ret)   
  175.         {   
  176.             return false;   
  177.         }   
  178.   
  179.         if (is_array($ret))   
  180.         {   
  181.             return false;   
  182.         }   
  183.         return $ret;   
  184.     }   
  185.   
  186.     function get($url$userAgent = ''$httpHeaders = ''$username = ''$password =   
  187.         '')   
  188.     {   
  189.         $ret = Curl_Class::execute('GET'$url''$userAgent$httpHeaders$username,   
  190.             $password);   
  191.         if (false === $ret)   
  192.         {   
  193.             return false;   
  194.         }   
  195.   
  196.         if (is_array($ret))   
  197.         {   
  198.             return false;   
  199.         }   
  200.         return $ret;   
  201.     }   
  202.   
  203.     function create()   
  204.     {   
  205.         $ch = null;   
  206.         if (!function_exists('curl_init'))   
  207.         {   
  208.             return false;   
  209.         }   
  210.         $ch = curl_init();   
  211.         if (!is_resource($ch))   
  212.         {   
  213.             return false;   
  214.         }   
  215.         return $ch;   
  216.     }   
  217.   
  218. }   
  219. ?>  


  4、主动监控守护进程
  脚本:/data0/monitor/monitor.sh
引用
#!/bin/sh
while true
do
   /bin/sh /data0/monitor/http.sh > /dev/null 2>&1
   /bin/sh /data0/monitor/tcp.sh > /dev/null 2>&1
   /usr/local/php/bin/php /data0/monitor/mysql.php > /dev/null 2>&1
   sleep 10
done


  启动主动监控守护进程:
/usr/bin/nohup /bin/sh /data0/monitor/monitor.sh 2>&1 > /dev/null &



  三、被动报告监控(“被监控机”采集数据发送给“监控机”)
  1、磁盘空间使用量监控
  2、磁盘Inode使用量监控
  3、Swap交换空间使用量监控
  4、系统负载监控
  5、Apache进程数监控

  被动监控这部分,在我的文章《写完“Linux服务器监控系统 ServMon V1.1” 》中已经实现,就不再详细写出。
      原文链接:http://blog.s135.com/read.php/354.htm]
分享到:
评论

相关推荐

    用Python脚本实现对Linux服务器的监控

    sync(文件系统安全监控软件)、glances(资源监控工具)在实际工作中,Linux系统管理员可以根据自己使用的服务器的具体情况编写一下简单实用的脚本实现对Linux服务器的监控。本文介绍一下使用Python脚本实现对Linux...

    基于Linux的中小型图书馆E-mail服务器的实现.pdf

    【基于Linux的中小型图书馆E-mail服务器的实现】 随着信息技术的发展,图书馆信息化进程加速,网络化服务成为图书馆不可或缺的一部分。E-mail服务因其便捷性、高效性和经济性,在图书馆的各项服务中扮演着重要角色...

    Linux运维-03-监控专题-day03-模板与zabbix报警&zabbixp

    Linux运维-03-监控专题-day03-模板与zabbix报警&zabbixproxy案例-16-主动监控与被动监控.mp4

    Linux环境下E—mail系统的设计与实现

    ### Linux环境下E—mail系统的设计与实现 #### 概述 随着互联网技术的快速发展,电子邮件(E-mail)作为网络中最基础且重要的服务之一,扮演着不可或缺的角色。据统计,互联网上超过30%的业务量与电子邮件相关。...

    Linux服务器多功能监控报警B/S系统

    一个用于Linux下全文检索数据库的服务器监控系统,。支持监控TRSServer全文检索服务器,可以支持其检索功能,监控数据同步是否正常,监控进程存在,以及数据库索引问题。 同时可监控Linux系统的运行状态,监控磁盘...

    Linux服务器下流量监控报警系统shell脚本实现.pdf

    Linux服务器下流量监控报警系统shell脚本实现.pdf

    基于 ARM-Linux-gcc、Linux-C、C# 实现的智能楼宇安全监控报警系统

    【作品名称】:基于 ARM-Linux-gcc、Linux-C、C# 实现的智能楼宇安全监控报警系统 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 ...

    嵌入式系统下Qt编写的E-mail收发终端

    在嵌入式系统中,构建一个基于Qt的E-mail收发终端是一项技术密集型的任务,涉及到多方面的知识。Qt是一个跨平台的C++图形用户界面应用程序框架,它为开发者提供了丰富的API,使得创建用户界面变得相对简单。在这个...

    python实战练习之实现linux下服务器监控

    公司总是会让我们人肉监控服务器状态(因为技术还没到互联网层公司的技术,没有自动化---例如工具Ansible之类的,ε=(´ο`*)))唉) 所以,我觉得这种东西如果可以实现一个远程自动化的监控工具是再好不过了。...

    Linux运维-03-监控专题-day02-prometheus安装与介绍-13

    Linux运维-03-监控专题-day02-prometheus安装与介绍-13-grafana+onealert报警2.mp4

    Linux远程监控设计与实现

    【Linux远程监控设计与实现】这篇文章主要探讨了如何在Linux环境下设计和实现一个远程监控系统,以实时监控服务器的CPU、内存和硬盘资源使用情况。该系统旨在提高网络管理的安全性和便利性。 1. **引言**: - 在...

    Linux服务器监控工具wgcloud-v2.3

    Linux服务器监控对于确保系统稳定运行和及时发现潜在问题至关重要。`wgcloud-v2.3` 是一款专为此目的设计的工具,它采用微服务架构,实现了分布式监控功能,能够覆盖多方面的监控需求。以下是该工具的主要特点和相关...

Global site tag (gtag.js) - Google Analytics