当前位置: 代码迷 >> MySQL >> Linx监控分享-着重点进程监控(mysqld)+邮件提醒
  详细解决方案

Linx监控分享-着重点进程监控(mysqld)+邮件提醒

热度:219   发布时间:2016-05-05 16:55:27.0
Linx监控分享--重点进程监控(mysqld)+邮件提醒

重点进程监控

mysqld:进程退出了,报警。没有退出则监控mysqld的(cpu(>=100%)|| mem(>=80%))开始提醒,同时收集和分析mysql状态信息;连接数(>=max_connections * 0.8)开始提醒;打开的句柄数(>=8192*0.8?)开始提醒。

待完善。。。

如果是单机多实例的话,只需要增加一个for循环就好了。

在手机上安装网易的邮件客户端,就可以达到实时提醒的效果。

关于mail的配置,见之前的文章:http://blog.csdn.net/rookie_ceo/article/details/46559195


#!/bin/shsource /etc/profileIP=`/sbin/ifconfig|sed -n '/inet addr/s/^[^:]*:\([0-9.]\{7,15\}\) .*/\1/p'|grep -v '127.0.0.1'`warn_pct=1 #75warn_name=[mysqld]performance_path=/monitor/performancemailtmp=/u01/soft/smonitor/mailtmplet/"$warn_name"tmp.mailinfotmp=/u01/soft/smonitor/mailtmplet/"$warn_name"tmp.tmp[email protected],[email protected] DT=`date +"%Y-%m-%d %H:%M:%S"`mysqld_pid=`ps -ef|grep  mysqld|grep -E "basedir|datadir" |grep -vE "mysqld_|grep"|awk '{print $2}'`#mysqld_pid=`ps -ef|grep  mysqld|grep -E "basedir|datadir" |grep -vE "mysqld_|grep|mysqld"|awk '{print $2}'`if [ "0" = "0$mysqld_pid" ]then              echo "您好:" >$mailtmp             echo "     [$DT]服务器:$IP mysqld进程已经退出,请注意。" #>>"$performance_path"/performance_$warn_name_$(date +%Y%m%d).log             echo "     [$DT]服务器:$IP mysqld进程已经退出,请注意。"  >> $mailtmp                          ps -ef|grep mysql  >>$mailtmp             echo -e "[$DT]$p1" >>$mailtmp             echo -e "\nBest Wishes! \n------------------------------------ \nCA system Monitor \n$DT" >> $mailtmp             cat $mailtmp| mailx -s "$warn_name[告警]:服务器:$IP" $maillistelse       echo "mysqld_pid=$mysqld_pid"      top -b -n 1 -p  $mysqld_pid >$infotmp      #cpu >= 100% 或者 mem >=80%  ##这里是约等于      over_pct_flag=`cat $infotmp | grep "^ *[1-9]" | awk '{ if($9 > 99 || $10 > 79) {print 1} else {print 2}}'`      echo "over_pct_flag==$over_pct_flag"      if [ 1 -eq "$over_pct_flag" ]      then             echo "您好:" >$mailtmp             echo "     [$DT]服务器:$IP mysqld进程CPU和Mem超过警戒值(cpu >= 100% 或者 mem >=80%),请注意。" #>>"$performance_path"/performance_$warn_name_$(date +%Y%m%d).log             echo "     [$DT]服务器:$IP mysqld进程CPU和Mem超过警戒值(cpu >= 100% 或者 mem >=80%),请注意。"  >> $mailtmp                          echo -e "[$DT]$p1" >>$mailtmp             cat $infotmp  >>$mailtmp             DT=`date +"%Y-%m-%d %H:%M:%S"`             echo -e "\nBest Wishes! \n------------------------------------ \nCA system Monitor \n$DT" >> $mailtmp             cat $mailtmp| mailx -s "$warn_name[告警]:服务器:$IP" $maillist      fifi


邮件提醒



版权声明:本文为博主原创文章,未经博主允许不得转载。

  相关解决方案