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++打开,然后执行以下步骤

  1. ctrl+a全选所有问题
  2. ctrl+x剪切所有内容
  3. notepad++中选中“格式->以UTF-8无BOM格式编码”
  4. ctrl+v将内容粘贴回来。
  5. 保存,并将Target文件拷贝会/etc/smokeping/config.d/Targets目录下。
  6. 如果使用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环境以后,

 

posted @ 2013-10-24 09:16  xwdreamer  阅读(6308)  评论(6编辑  收藏  举报