ubuntu下smokeping安装配置
0.参考文件
http://wenku.baidu.com/view/950fbb0a79563c1ec5da71b1
http://aaaxiang000.blog.163.com/blog/static/20634912201188696910/
http://my.oschina.net/lxcong/blog/150617#OSC_h1_20
1.为ubuntu设置固定ip地址
参考文献:http://hi.baidu.com/futuremeng/item/ce1604ee467d0b0f570f1d30
在安装好ubuntu以后,系统默认是使用DHCP自动获取ip地址。对ubuntu的ip地址修改都在/etc/network/interfaces这个文件下面。
在ubuntu下运行如下命令:
#sudo vim /etc/network/interfaces
使用vim来进行编辑,我们可以看到默认配置如下图所示:
上述的最后两条命令就表示是使用DHPC自动获取ip方式。
auto eth0
iface eth0 inet dhcp
现在我们要为其设置静态ip地址,设置方式如下,
运行#sudo vim /etc/network/interfaces。修改文件如下:
# This file describes the network interfaces available on your system # and how to activate them. For more information, see interfaces(5). # The loopback network interface auto lo iface lo inet loopback # The primary network interface auto eth0 #iface eth0 inet dhcp iface eth0 inet static address 10.138.16.245 netmask 255.255.255.240 gateway 10.138.16.254
最后使用下面的命令使网络设置生效:
sudo /etc/init.d/networking restart
2.安装smokeping
首先在ubuntu下运行如下命令,安装预备程序对于所有选项都选择Y,表示安装
sudo aptitude install rrdtool apache2 fping echoping libapache2-mod-speedycgi libwww-perl libsocket6-perl libnet-telnet-perl libnet-dns-perl libnet-ldap-perl libio-socket-ssl-perl libauthen-radius-perl libcgi-perl librrds-perl librrdp-perl
--------------------------------------------------------------------------
PS:2014-2-27
1.今天发现aptitude命令在ubuntu当中是有问题的,查了一下发现好像是ubuntu有bug,建议不要使用apttitude,直接使用apt-get这个命令。
2.还有一个就是上面的这些依赖包可能有问题,我又参考了Install and configure Smokeping on Ubuntu 12.04 LTS 这篇博客,在另外一台机器上面安装了smokeping,它所使用的依赖包如下:
sudo apt-get install smokeping curl libauthen-radius-perl libnet-ldap-perl libnet-dns-perl libio-socket-ssl-perl libnet-telnet-perl libsocket6-perl libio-socket-inet6-perl apache2
3.还有我在bitnami的机器上面安装smokeping失败,总是无法打开,后来查了一下发现是因为bitnami中使用的是apache2.4,而smokeping更加兼容apche2.2版本。或者也有可能bitnami当中对apache做了修改,而smokeping在这个基础上安装不兼容,anyway,smokeping不能在bitnami上面部署。
---------------------------------------------------------------------------------------
然后在运行smokeping安装命令
sudo apt-get install smokeping
最后使用在浏览器上面输入:http://[IP]/cgi-bin/smokeping.cgi进行访问,如果输入这个地址以后出现sendmail错误的,还需要安装sendmail,命令如下:
sudo apt-get install sendmail
3.中文支持
3.1中文文字
如果Targets 文件中出现中文,需要修改Presentation 文件,
#sudo vim /etc/smokeping/config.d/Presentation
设定 charset = UTF8 。在设定完毕以后,我们再次打开Targets文件,如果文件出现乱码, 需要全部重新编辑才可以,也就是说再一次以utf-8的格式输入一次中文。重启smokeping ,刷新界面,中文就不会出现乱码了。如下图所示:
ps:2014-2-27
其实也可以不用重新输入一遍,我们可以将Target文件拷贝出来,在我们的windows操作系统上面用notepad++打开,然后执行以下步骤
- ctrl+a全选所有问题
- ctrl+x剪切所有内容
- notepad++中选中“格式->以UTF-8无BOM格式编码”
- ctrl+v将内容粘贴回来。
- 保存,并将Target文件拷贝会/etc/smokeping/config.d/Targets目录下。
- 如果使用secureCRT打开,还需要修改其编码方式,参考:securecrt中文乱码以及ubuntu设置locale
3.2图片的中文支持
如果想要图rrd图片也支持中文,那么就需要中文字体包了,
sudo apt-get install ttf-wqy-zenhei
如果你跟我一样是处于离线环境,可以下载一个文泉驿字体安装包再安装。具体安装方法参考我另外一篇博客:ubuntu单独安装字体包。我也将字体安装包以及依赖包放到百度云盘上面了,下载地址:http://pan.baidu.com/s/1hqsUORi 。
然后修改smokeping的Graphs.pm这个文件,如果找不到的话可以通过find命令查到
enadmin@BJCGNMON01:/etc/smokeping/config.d$ sudo find / -name Graphs.pm [sudo] password for enadmin: /home/enadmin/Graphs.pm /usr/share/perl5/Smokeping/Graphs.pm
通过查找命令我们知道需要修改“/usr/share/perl5/Smokeping/Graphs.pm”这个文件,我们找到RRDs::graph,然后在里面插入如下语句:
'--font TITLE:20:"WenQuanYi Zen Hei Mono"',
if ($mode =~ /[anc]/){ my $val = 0; for my $host (@hosts){ my ($graphret,$xs,$ys) = RRDs::graph ("dummy", '--start', $tasks[0][1], '--end', $tasks[0][2], '--font TITLE:20:"WenQuanYi Zen Hei Mono"', "DEF:maxping=$cfg->{General}{datadir}${host}.rrd:median:AVERAGE", 'PRINT:maxping:MAX:%le' ); my $ERROR = RRDs::error(); return "<div>RRDtool did not understand your input: $ERROR.</div>" if $ERROR; $val = $graphret->[0] if $val < $graphret->[0]; } $val = 1e-6 if $val =~ /nan/i; $max = { $tasks[0][1] => $val * 1.5 }; }
如果你Smokeping的安装路径不是上述安装路径,你可以在ubuntu下搜索Graphs.pm这个文件,在查到路径以后在去编辑文件。
sudo find / -name Graphs.pm
4.添加smokeping节点
在ubuntu执行以下命令来编辑配置文件:
sudo vim /etc/smokeping/config.d/Targets
按照样例我们添加节点的ip地址
+ Gansu //注意,这里加号后面的必须是英文,不能是中文 menu = 甘肃 title = 甘肃 ++ Daliang //同样,这里‘++’后面的必须是英文,+和++后面的内容是不会被现实的,只是起一个命名的作用。 menu =大梁 title =大梁:10.138.1.11 host = 10.138.1.11 alerts = someloss
在添加完毕以后重启smokeping,执行以下mingling:
#sudo /etc/init.d/smokeping restart
ps:添加三级目录
前面的配置是二级目录,其实smokeping是可以配置三级目录的,如下所示:
+ yiji menu = 一级 title = 一级 ++ erji menu = 二级 title = 二级 +++ sanji menu = sanji title =sanji:10.138.16.54 host = 10.138.16.54 alerts = someloss
5.邮件告警配置:
5.1概述
smokeping默认使用邮件进行alert,也可以直接调用外部程序进行IM的报警,也就是说你只需要写一个简单的shell脚本,就可以实现smokeping的MSN 、 gtalk 、飞信等IM、短信报警了。如果要配置smokeping的告警功能,我们需要修改/etc/smokeping/config.d/Alerts这个配置文件,我的配置文件如下:
*** Alerts *** to = |/etc/smokeping/alert.sh from = aaa@126.com +someloss type = loss # in percent pattern = >90%,*12*,>90%,*12*,>90% edgetrigger = yes comment = loss 3 times in a row +rttbad type = rtt # in milliseconds pattern = ==S,>50,>50 edgetrigger = yes comment = route # This rule checks for 3 periods (3 * 5min default) where # the rtt is >70ms +rttdetect type = rtt # in milli seconds pattern = >70,>70,>70 edgetrigger = yes comment = On backup circuit maybe?
5.1.1配置触发脚本
"to" 选项,默认是要填入一个email地址的,但是只要在"="后面加上"|",后面再跟你自定义的脚本路径,就可以调用自己的脚本进行alert了。
比如我们这里的/etc/smokeping/alert.sh就是我自己定义的告警脚本。这个脚本会读入5个[或者6个]参数:name-of-alert, target, loss-pattern, rtt-pattern, hostname,[raise],自己选择要使用的参数即可,我的alert.sh脚本内容如下所示,之所以打印出所有的参数,是为了看看每个参数都是些什么内容。
#!/bin/sh echo "$2 got smokeping $1 from Monitor Server, The $2 IP is: $5........name-of-alert:$1, target:$2, loss-pattern:$3, rtt-pattern:$4, hostname:$5,[raise]:$6" |mutt -s "smokeping alert $2" xwdreamer@126.com
5.1.2设置发件人邮箱
"from"选项中填入我们的发件人邮箱地址。
5.1.3设置告警出发类型
smokeping的告警分为条件触发和边界触发,所谓条件触发就是只要满足条件就会触发,比如我们ping不通一个站点,那么smokeping就一直发告警,直到能够ping通为止;还有一种是边界触发,所谓边界触发就是只在状态发生改变的时候发出告警。这样断开的时候发一封邮件,恢复的时候再发一封邮件。我们这里就是要使用边界触发,所以设置“edgetrigger” = yes。
alert的类型我们主要使用"loss"和"rtt"两种(当然还有更多更复杂的类型)。上面的alert类型当中,我只用了someloss这个类型,具体解释是只要在12次测试当中,如果出现3次丢包,并且丢包率达到90%,那么就告警。下面我再给出一些其他规则的告警触发条件解释:
#如果在12次检查中出现了3次丢包的情况(不论丢多少个包),就进行alert; +someloss type = loss # in percent pattern = >0%,*12*,>0%,*12*,>0% comment = loss 3 times in a row #如果连续出现两次50毫秒以上的延时,就进行alert; +rttbad type = rtt # in milliseconds pattern = ==S,>50,>50 comment = route #之前5次检查延时都少于10毫秒,前6次检查延时都少于100毫秒,第7次开始连续3次检查延时都大于100毫秒的话,就进行alert。 +rttdetect type = rtt # in milliseconds pattern = <10,<10,<10,<10,<10,<100,>100,>100,>100 comment = routing messed up again ?
5.2smokeping与msmtp的集成
smokeping默认的邮件告警是使用sendmail来实现的,如果想直接通过smpt发送邮件需要修改源代码,觉得这样不方便,后来找了一些资料,使用msmtp来实现。所以首先安装msmtp+mutt环境,参考:ubuntu下msmtp+mutt的安装和配置 。在这篇博客中提到,哪个用户要使用msmtp和mutt,那么哪个用户就必须对.msmtprc和.muttrc这两个文件有读写的权限。现在我们要smokeping程序中调用mutt和msmtp命令,那么运行smokeping程序的用户就必须对.msmtprc和.muttrc这两个文件有读写的权限。
5.3查看smokeping进程所属的用户
enadmin@cgnmon:~/test$ ps -aux | grep smokeping Warning: bad ps syntax, perhaps a bogus '-'? See http://procps.sf.net/faq.html 105 1265 0.0 1.0 142248 22244 ? Ss 09:04 0:00 /usr/sbin/smokeping [FPing] enadmin 1930 0.0 0.0 11700 964 pts/0 S+ 09:29 0:00 grep --color=auto smokeping
从上面我们可以看到smokeping进程的用户是105,那么105具体指谁呢,我们可以在/etc/passwd(还有一个/etc/shadow)当中查看。如下所示,我们执行
vi /etc/passwd
发现一个用户叫做smokeping:x:105,这个105用户就是smokeping用户,我们同样能够在这个下找到root账户和enadmin账户。
enadmin@cgnmon:~/test$ vi /etc/passwd root:x:0:0:root:/root:/bin/bash daemon:x:1:1:daemon:/usr/sbin:/bin/sh bin:x:2:2:bin:/bin:/bin/sh sys:x:3:3:sys:/dev:/bin/sh sync:x:4:65534:sync:/bin:/bin/sync games:x:5:60:games:/usr/games:/bin/sh man:x:6:12:man:/var/cache/man:/bin/sh lp:x:7:7:lp:/var/spool/lpd:/bin/sh mail:x:8:8:mail:/var/mail:/bin/sh news:x:9:9:news:/var/spool/news:/bin/sh uucp:x:10:10:uucp:/var/spool/uucp:/bin/sh proxy:x:13:13:proxy:/bin:/bin/sh www-data:x:33:33:www-data:/var/www:/bin/sh backup:x:34:34:backup:/var/backups:/bin/sh list:x:38:38:Mailing List Manager:/var/list:/bin/sh irc:x:39:39:ircd:/var/run/ircd:/bin/sh gnats:x:41:41:Gnats Bug-Reporting System (admin):/var/lib/gnats:/bin/sh nobody:x:65534:65534:nobody:/nonexistent:/bin/sh libuuid:x:100:101::/var/lib/libuuid:/bin/sh syslog:x:101:103::/home/syslog:/bin/false messagebus:x:102:105::/var/run/dbus:/bin/false whoopsie:x:103:106::/nonexistent:/bin/false landscape:x:104:109::/var/lib/landscape:/bin/false enadmin:x:1000:1000:enadmin,,,:/home/enadmin:/bin/bash smokeping:x:105:114:SmokePing daemon,,,:/var/lib/smokeping:/bin/false smmta:x:106:115:Mail Transfer Agent,,,:/var/lib/sendmail:/bin/false smmsp:x:107:116:Mail Submission Program,,,:/var/lib/sendmail:/bin/false sshd:x:108:65534::/var/run/sshd:/usr/sbin/nologin ftp:x:109:117:ftp daemon,,,:/srv/ftp:/bin/false ntp:x:110:118::/home/ntp:/bin/false openldap:x:111:119:OpenLDAP Server Account,,,:/var/lib/ldap:/bin/false
但是我们发现这个smokeping用户的后缀是/bin/false,这个后缀表示此账户是无法登陆的,如果要想使用smokeping登陆,或者进入到smokeping账户目录下,那么必须让这个账户变为可登陆。那么如何设置呢,我们可以参考enadmin账户的后缀,他的后缀都是/bin/bash,那么我们就将smokeping账户的后缀修改为/bin/bash,然后重启一下即可。具体参考:系统账户更改为可登陆账户
5.4修改.msmtprc和.muttrc这两个文件的权限
在我们搭建好msmpt和mutt环境以后,