zoukankan      html  css  js  c++  java
  • 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环境以后,

  • 相关阅读:
    【spring-boot】spring-boot 事物管理——之注解@Transactional
    【spring-boot】Spring-boot学习-helloWorld
    【Maven】failOnMissingWebXml
    【java基础领域】高内聚、低耦合理解
    Pascal's Triangle
    Remove Nth Node From End of List
    Valid Palindrome
    Longest Common Prefix
    Roman to Integer
    Palindrome Number
  • 原文地址:https://www.cnblogs.com/xwdreamer/p/3385381.html
Copyright © 2011-2022 走看看