告警系统主脚本、告警系统配置文件、告警系统监控项目

前端之家收集整理的这篇文章主要介绍了告警系统主脚本、告警系统配置文件、告警系统监控项目前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

十七周一次课(2月9日)

20.20 告警系统主脚本

  • 创建目录
  1. [root@qingyun-01 ~]# cd /usr/local/sbin/
  2. #进入到/usr/local/sbin/目录下
  3.  
  4. [root@qingyun-01 sbin]# mkdir mon
  5. #创建子目录
  6.  
  7. [root@qingyun-01 sbin]# cd mon
  8. [root@qingyun-01 mon]# mkdir bin conf shares log mail
  9. #创建 bin conf shares log mail
  10.  
  11. [root@qingyun-01 mon]# cd bin
  12. #bin 为主目录
  13.  
  14. [root@qingyun-01 bin]#
  15.  
  16. [root@qingyun-01 bin]# vim main.sh
  17. #创建 入口shell脚本文件 main.sh
  1. #!/bin/bash
  2. #Written by taoyuan
  3. # 是否发送邮件的开关
  4. export send=1
  5. # 过滤ip地址
  6. export addr= `/sbin/ifconfig |grep -A1 "ens33: "|awk '/inet/ {print $2}'`
  7. dir=`pwd`
  8. #只需要最后一级目录名
  9. last_dir=`echo $dir|awk -F '/' '{print $NF}'`
  10. #下面的判断目的是,保证执行脚本的时候,我们在bin目录里,不然监控脚本、邮件和日志很有可能找不到
  11. if [ $last_dir == "bin" ] || [ $last_dir == "bin/" ]; then
  12. conf_file="../conf/mon.conf"
  13. else
  14. echo "you shoud cd bin dir"
  15. exit
  16. fi
  17. exec 1>>../log/mon.log 2>>../log/err.log
  18. echo "`date +"%F%T"` load average"
  19. /bin/bash ../shares/load.sh
  20. #先检查配置文件中是否需要监控502
  21. if grep -q 'to_mon_502=1' $conf_file; then
  22. export log=`grep 'logfile=' $conf_file |awk -F '=' '{print $2}' |sed's/ //g'`
  23. /bin/bash ../shares/502.sh
  24. fi

20.21 告警系统配置文件

  1. ##to config the options if to monitor
  2. ## 定义MysqL的服务器地址、端口以及user、password
  3. to_mon_cdb=0 ##0 or 1,default 0,0 not monitor,1 monitor
  4. db_ip=10.20.3.13
  5. db_port=3315
  6. db_user=username
  7. db_pass=passwd
  8. ## httpd 如果是1则监控,为0不监控
  9. to_mon_httpd=0
  10. ## PHP 如果是1则监控,为0不监控
  11. to_mon_PHP_socket=0
  12. ## http_code_502 需要定义访问日志的路径
  13. to_mon_502=1
  14. logfile=/data/log/xxx.xxx.com/access.log
  15. ## request_count 定义日志路径以及域名
  16. to_mon_request_count=0
  17. req_log=/data/log/www.discuz.net/access.log
  18. domainname=www.discuz.net

20.22 告警系统监控项目

告警系统load.sh

  1. #!/bin/bash
  2. ##Writen by taoyuan##
  3. load=`uptime |awk -F 'average:' '{print $2}'|cut -d',' -f1|sed 's/ //g'|cut -d. -f1`
  4. if [ $load -gt 20 ] && [ $send -eq "1" ]
  5. then
  6. echo "$addr `date+%T` load is $load" >../log/load.tmp
  7. /bin/bash ../mail/mail.sh $addr\_load $load ../log/load.tmp
  8. fi
  9. echo "`date +%T` load is $load"
  • sheres目录
  1. [root@qingyun-01 mon]# cd shares/
  2. [root@qingyun-01 shares]# vim load.sh

告警系统502.sh

  1. #1 /bin/bash
  2. d=`date -d " 1 min" +%H:%M`
  3. c_502=`grep :$d: $log |grep ' 502 '|wc -l`
  4. if [ $c_502 -gt 10 ] && [ $send == 1 ]; then
  5. echo "$addr $d 502 count is $c_502">../log/502.tmp
  6. /bin/bash ../mail/mail.sh $addr\_502 $c_502 ../log/502.tmp
  7. fi
  8. echo "`date +%T` 502 $c_502"

告警系统disk.sh

  1. #!/bin/bash
  2. ##Writen by taoyuan##
  3. rm -f ../log/disk.tmp
  4. for r in `df -h |awk -F '[ %]+' '{print $5}'|grep -v Use`
  5. do
  6. if [ $r -gt 90 ] && [ $send -eq "1" ]
  7. then
  8. echo "$addr `date +%T` disk useage is $r" >>../log/disk.tmp
  9. fi
  10. if [ -f ../log/disk.tmp ]
  11. then
  12. df -h >>../log/disk.tmp
  13. /bin/bash ../mail/mail.sh $addr\_disk $r ../log/disk.tmp
  14. echo "`date +%T` disk useage is nook"
  15. else
  16. echo "`date +%T` disk useage in ok"
  17. fi

猜你在找的Bash相关文章