smokeping 报警配置
摘自:
http://blog.csdn.net/achejq/article/details/51556494
smokeping 默认用sendmail 发邮件告警,也可以直接调用外部程序进行报警。smokeping的alert设置有点复杂,但是却很好用,设置很灵活,考虑得很周全。
一、配置邮件支持
默认情况下sendmail 是不通过163、qq之类的邮件服务器发送的,不过我们略微修改下配置即可以支持。首先需要安装 Authen::SASL 模块(auth 需要用的),然后修改 smokeping/lib/Smokeping.pm 。
如下:
- #头上加
- use Authen::SASL;
- #定位到sendmail函数,默认新版本sendmail函数的定义的已经是下面这样了,如果不是改成下面这样
- sub sendmail ($$$){
- my $from = shift;
- my $to = shift;
- $to = $1 if $to =~ /<(.*?)>/;
- my $body = shift;
- if ($cfg->{General}{mailhost} and
- my $smtp = Net::SMTP->new([split /\s*,\s*/, $cfg->{General}{mailhost}],Timeout=>5) ){
- $smtp->auth(split(/\s*,\s*/, $cfg->{General}{mailusr}),split(/\s*,\s*/, $cfg->{General}{mailpwd}));
- $smtp->mail($from);
- $smtp->to(split(/\s*,\s*/, $to));
- $smtp->data();
- $smtp->datasend($body);
- $smtp->dataend();
- $smtp->quit;
- } elsif ($cfg->{General}{sendmail} or -x "/usr/lib/sendmail"){
- open (M, "|-") || exec (($cfg->{General}{sendmail} || "/usr/lib/sendmail"),"-f",$from,$to);
- print M $body;
- close M;
- } else {
- warn "ERROR: not sending mail to $to, as all methodes failed\n";
- }
- }
- #找到 '_vars =>' ,把 mailusr mailpwd 加进去。不然不能启动哦!General configuration values valid for the whole SmokePing setup.
- DOC
- _vars =>
- [ qw(owner imgcache imgurl datadir dyndir pagedir piddir sendmail offset
- smokemail cgiurl mailhost mailusr mailpwd snpphost contact display_name
- syslogfacility syslogpriority concurrentprobes changeprocessnames tmail
- changecgiprogramname linkstyle precreateperms ) ],
配置完成后修改配置文件/opt/smokeping/etc/config ,增加邮件服务器的配置:
- mailhost = smtp.361way.com
- mailusr = monitor@361way.com
- mailpwd = xxxxxxxxx
二、Alerts部分配置
1、自定义alerts告警策略
如下定义了几种告警策略,bigloss 、someloss等
- *** Alerts ***
- to = admin@361way.com
- from = monitor@361way.com
- +bigloss
- type = loss
- # in percent
- pattern = ==0%,==0%,==0%,==0%,>0%,>0%,>0%
- comment = suddenly there is packet loss
- +someloss
- type = loss
- # in percent
- pattern = >0%,*12*,>0%,*12*,>0%
- comment = loss 3 times in a row
- +startloss
- type = loss
- # in percent
- pattern = ==S,>0%,>0%,>0%
- comment = loss at startup
- +rttdetect
- type = rtt
- # in milli seconds
- pattern = <10,<10,<10,<10,<10,<100,>100,>100,>100
- comment = routing messed up again ?
- +hostdown
- type = loss
- # in percent
- pattern = ==0%,==0%,==0%, ==U
- comment = no reply
- +lossdetect
- type = loss
- # in percent
- pattern = ==0%,==0%,==0%,==0%,>20%,>20%,>20%
- comment = suddenly there is packet loss
以上几种告警,这里选取三种说明如下:
- someloss: 如果在12次检查中出现了3次丢包的情况(不论丢多少个包),就进行alert;
- rttbad:
如果连续出现两次50毫秒以上的延时,就进行alert; - rrtdetect:
之前5次检查延时都少于10毫秒,前6次检查延时都少于100毫秒,第7次开始连续3次检查延时都大于100毫秒的话,就进行alert。
2、策略应用
在target里面加上相应的策略配置即可,如下:
- ++ 361way
- menu = 361way_host
- title =361way.com
- host = www.361way.com
- alerts = someloss,hostdown
主机一旦出现告警,就会通过邮件发送到我们事先配置的邮箱中,类似下图:
上图中的邮件告警内容也可以进行自定义格式输出和修改,这个还是修改Smokeping.pm文件,修改其中如下部分即可:
- my $default_mail = <<DOC;
- Subject: [SmokeAlert] <##ALERT##> <##WHAT##> on <##LINE##>
- <##STAMP##>
- Alert "<##ALERT##>" <##WHAT##> for <##URL##>
- Pattern
- -------
- <##PAT##>
- Data (old --> now)
- ------------------
- <##LOSS##>
- <##RTT##>
- Comment
- -------
- <##COMMENT##>
- DOC
3、pattern匹配
pattern匹配是编写alert规则中很最要的一部分,官方对这部分有说明,不过我查到了一个香港同胞总结的要好一些,这里摘录下,不做翻译了。
三、特殊调用
1、外部程序调用
调用外部告警程序,如IM、短信等的示例如下:
- *** Alerts ***
- to = |/usr/local/smokeping/bin/alert.sh
- from = joe@somehost
"to" 选项,默认是要填入一个email地址的,但是只要在"="后面加上"|",后面再跟你自定义的脚本的路径,就可以调用自己的脚本进行alert了。脚本会读入5或者6个参数:name-of-alert, target, loss-pattern, rtt-pattern, hostname,[raise]。自己选择使用哪些参数alert即可。
这里从老外站点上找到有一个示例如下:
config 配置
- to = |/etc/smokeping/config.d/trace_alert.sh 2> /tmp/trace.log
脚本内容:
- ########################################################
- # Script to email a mtr report on alert from Smokeping #
- ########################################################
- alertname=$1
- target=$2
- losspattern=$3
- rtt=$4
- hostname=$5
- email="monitoring@email.com"
- smokename="BR-NYC-"
- if [ “$losspattern" = “loss: 0%" ];
- then
- subject="Clear-${smokename}-Alert: $target host: ${hostname}"
- else
- subject="${smokename}Alert: ${target} – ${hostname}"
- fi
- echo “MTR Report for hostname: ${hostname}" > /tmp/mtr.txt
- echo “" >> /tmp/mtr.txt
- echo “sudo mtr -n –report ${hostname} "
- sudo /usr/sbin/mtr -n –report ${hostname} >> /tmp/mtr.txt
- echo “" >> /tmp/mtr.txt
- echo “Name of Alert: " $alertname >> /tmp/mtr.txt
- echo “Target: " $target >> /tmp/mtr.txt
- echo “Loss Pattern: " $losspattern >> /tmp/mtr.txt
- echo “RTT Pattern: " $rtt >> /tmp/mtr.txt
- echo “Hostname: " $hostname >> /tmp/mtr.txt
- echo “" >> /tmp/mtr.txt
- echo “Full mtr command is: sudo /usr/sbin/mtr -n –report ${hostname}" >> /tmp/mtr.txt
- echo “subject: " $subject
- if [ -s /tmp/mtr.txt ] then
- mailx -s “${subject}" $email
- fi
2、特定主机发送到特定用户
to 表示接受所有报警的邮箱,如果需要在特定的节点报警发送到特定的邮箱
则在该节点上增加alertee = testmonitor@139.com即可。具体可以参看/opt/smokeping/lib/Smokeping.pm源码,如下部分:
- foreach my $addr (map {$_ ? (split /\s*,\s*/,$_) : ()} $cfg->{Alerts}{to},$tree->{alertee},$alert->{to}){
smokeping 报警配置的更多相关文章
- 自学Zabbix3.10.2-事件通知Notifications upon events-Actions报警配置
点击返回:自学Zabbix之路 点击返回:自学Zabbix4.0之路 点击返回:自学zabbix集锦 自学Zabbix3.10.2-事件通知Notifications upon events-Acti ...
- 【阿里云IoT+YF3300】6.物联网设备报警配置
纵然5G时代已经在时代的浪潮中展现出了它的身影,但是就目前的物联网环境中,网络问题仍旧是一个比较突出的硬伤.众所周知,在当前的物联网规划中,与其说是实现万物互联,倒不如说是行业指标数据监控.对于一些特 ...
- smokeping 微信报警配置
1. 准备alert脚本,用来调用微信脚本 #!/bin/bash alertname=$ target=$ losspattern=$ rtt=$ smokename="hq_to_idc ...
- ubuntu下smokeping安装配置
0.参考文件 http://wenku.baidu.com/view/950fbb0a79563c1ec5da71b1 http://aaaxiang000.blog.163.com/blog/sta ...
- zabbix 邮件报警配置
zabbxi 邮件告警推送有两种方式: 1.使用zabbix服务端的本地邮箱账号发送,邮件名为:user@hostname.localdomain,user为发送邮件的用户,hostname为zabb ...
- Zabbix邮件报警配置
一.安装sendmail或者postfix yum install sendmail #安装 service sendmail start #启动 chkconfig sendmail on #设置开 ...
- zabbix3.0.4安装部署与SendEmail报警配置
MySQL:5.6.21 nginx:1.62 PHP:5.7 pcre:8.32 zabbix:3.0.4 LNMP安装步骤略过 # tar xvf zabbix-3.0.4.tar.gz # cd ...
- CentOS7.3下Zabbix3.5之微信报警配置
一.报警脚本放到服务端的 /usr/lib/zabbix/alertscripts/下 属组属主为zabbix zabbix 有执行权限vim weixinbaojing.py # ...
- CentOS7.3下Zabbix3.5之邮件报警配置
一.邮件客户端以及脚本相关配置 1.安装sendmail,一般操作系统默认安装了安装 yum install sendmail 启动 service sendmail start 设置开机启动 chk ...
随机推荐
- vue 组件创建与销毁
vue 组件(如对话框组件)实时创建与销毁: 使用v-if <search-history :show="showSearchHistory" @close="sh ...
- 『HTML5梦幻之旅』 - 仿Qt演示样例Drag and Drop Robot(换装机器人)
起源 在Qt的演示样例中看到了一个有趣的demo.截图例如以下: 这个demo的名字叫Drag and Drop Robot,简单概括而言,在这个demo中,能够把机器人四周的颜色拖动到机器人的各个部 ...
- rtmp 错误 Server error: call to function _checkbw failed
客户端使用rtmp协议与rtmp服务通信如遇到 Server error: call to function _checkbw failed错误 需要在服务端修改代码.如服务端使用的是CrtmpSer ...
- python中给程序加锁之fcntl模块的使用
python 中给文件加锁——fcntl模块import fcntl 打开一个文件##当前目录下test文件要先存在,如果不存在会报错.或者以写的方式打开f = open('./test')对该文件加 ...
- 兔子--改动Android Studio的快捷键,改动成eclipse的快捷键
仅仅须要2步 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMzQyNTUyNw==/font/5a6L5L2T/fontsize/400/fill ...
- 手把手实现andriod应用增量升级
近期研究了android应用增量升级的应用.当中用到了android NDK编程,先说下为什么要使用增量升级.当我们的应用达到一定大小的时候,比方眼下有30M.假设新版本号35M仅仅是添加了几个功能, ...
- CSS3 实现背景透明,文字不透明,兼容所有浏览器
<!DOCTYPE html><html><head><meta charset="utf-8"><title>opac ...
- log4j:WARN Please initialize the log4j system properly.
在tomcat启动的时候,出现这个警告: log4j:WARN No appenders could be found for logger (org.apache.commons.digester. ...
- Spark源码分析之二:Job的调度模型与运行反馈
在<Spark源码分析之Job提交运行总流程概述>一文中,我们提到了,Job提交与运行的第一阶段Stage划分与提交,可以分为三个阶段: 1.Job的调度模型与运行反馈: 2.Stage划 ...
- linux uart驱动——uart原理(一)
UART(Universal Asynchronous Receiver and Transmitter)通用异步收发器(异步串行通信口),是一种通用的数据通信协议,它包括了RS232.RS499.R ...