Smokeping 主要是监视网络性能,包括常规的 ping,用 echoping 监视 www 服务器性能,监视 dns 查询性能,监视 ssh 性能等。底层也是 rrdtool 做支持,特点是画的图非常漂亮,网络丢包和延迟用颜色和阴影来表示。下面我们来开始安装Smokeping
rpm -Uvh http://apt.sw.be/redhat/el6/en/x86_64/rpmforge/RPMS/rpmforge-release-0.5.3-1.el6.rf.x86_64.rpm
yum -y install perl perl-Net-Telnet perl-Net-DNS perl-LDAP perl-libwww-perl perl-RadiusPerl perl-IO-Socket-SSL perl-Socket6 perl-CGI-SpeedyCGI perl-FCGI perl-CGI-SpeedCGI perl-Time-HiRes
yum -y install perl-ExtUtils-MakeMaker perl-RRD-Simple rrdtool rrdtool-perl curl fping echoping gcc make wget libxml2-devel libpng-devel glib pango
yum -y install pango-devel freetype freetype-devel fontconfig cairo cairo-devel libart_lgpl libart_lgpl-devel mod_fastcgi screen
wget http://oss.oetiker.ch/smokeping/pub/smokeping-2.6.8.tar.gz tar xvzf smokeping-2.6.8.tar.gz cd smokeping-2.6.8 ./configure --prefix=/usr/local/smokeping
出现问题是因为需要安装perl的模块,所以运行下面内容即可
./setup/build-perl-modules.sh /usr/local/smokeping/thirdparty
继续运行
./configure --prefix=/usr/local/smokeping gmake install cd /usr/local/smokeping mkdir cache data var touch /var/log/smokeping.log chown apache:apache cache data var chown apache:apache /var/log/smokeping.log cd /usr/local/smokeping/htdocs/ mv smokeping.fcgi.dist smokeping.fcgi cd /usr/local/smokeping/etc mv config.dist config vi config cgiurl = http://some.url/smokeping.cgi 把some.url修改为你的ip或者域名
*** Database ***
step = 300
pings = 20
然后修改step,从300改为60,这是检测的时间, pings 从20 改为60, 即60秒ping 60次
修改apache的配置
vim /etc/httpd/conf/httpd.conf
在DocumentRoot "/var/www/html"
这一行之下添加如下内容: 用#号注释掉的是验证部分 可有可无
Alias /cache "/usr/local/smokeping/cache/" Alias /cropper "/usr/local/smokeping/htdocs/cropper/" Alias /smokeping "/usr/local/smokeping/htdocs/smokeping.fcgi"AllowOverride None Options All AddHandler cgi-script .fcgi .cgi Order allow,deny Allow from all #AuthName "Smokeping" #AuthType Basic #AuthUserFile /usr/local/smokeping/htdocs/htpasswd #Require valid-user DirectoryIndex smokeping.fcgi
如果要启用验证,那取消#号
进入
cd /usr/local/smokeping/htdocs
目录, 执行命令:
htpasswd -c /usr/local/smokeping/htdocs/htpasswd admin echo "/usr/local/smokeping/bin/smokeping --logfile=/var/log/smokeping.log 2>&1 &" >> /etc/rc.local chkconfig httpd on chkconfig iptables off /etc/init.d/httpd start /usr/local/smokeping/bin/smokeping --logfile=/var/log/smokeping.log 2>&1 &
特别说明:
修改/usr/local/smokeping/etc/config 文件的配置参数,必须重启动smokeping程序
(1)如果重启动smokeping程序失败,根据报错提示删除/usr/local/smokeping/data子文件夹的rrd文件
(2)中文问题:如果需要在网页里展示中文,修改/usr/local/smokeping/etc的config文件
*** Presentation *** charset = utf-8 //注:在这里添加
然后在menu与titile里修改中文,重启即可
有一个要注意的地方就是,你输入的中文必须在utf-8的字符编码下输入的中文字符,不然会出现乱码。
如果在xshel下,选择file-properities-terminal
如果还是不显示就看看你系统里是否安装了中文字体,或者在安装一个
三. 添加需要监控的网站和节点(在/usr/local/smokeping/etc/config中添加) * smokeping就这点不好,添加节点不能在前台Web页面添加,一定要在后台的配置文件中添加,希望以后的版本中能改进一下 * * 修改/usr/local/smokeping/etc/config 后,必须重启smokeping 程序,配置才会生效 * * smokeping 会根据配置文件config 在/usr/local/smokeping/data 之下添加moniter文件夹,其下包含website子文件夹 * * 用vmware workstation的虚拟机测试有一点好处,workstation下的虚拟网卡可以设置出入的丢包率,适合smokeping做丢包测试, 经过测试smokeping检测出的丢包率与vmware worksation虚拟网卡设置的丢包率基本相同,也就是说smokeping 能够反应网络的真实状况 * 添加监控节点示例:注意+是第一层,++是第二层,+++ 是第三层
+ moniter
menu = moniter
++ website
menu = website
title = moniter
website
#host = /moniter/website/baidu /moniter/website/sina /moniter/website/taobao /moniter/website/QQ
+++ baidu
menu = baidu
title = baidu.com
alerts = someloss
host = www.baidu.com
+++ sina
menu = sina
title = sina.com.cn
alerts = someloss
host = www.sina.com.cn
+++ taobao
menu = taobao
title = taobao.com
alerts = someloss
host = www.taobao.com
默认不支持中文,不过修改也很简单
1.页面支持中文
在配置文件的*** Presentation ***下添加
charset = utf-8
2.rrd图片支持中文
yum -y install wqy-zenhei-fonts.noarch
修改配置文件/opt/smokeping-2.6.9/lib/Smokeping/Graphs.pm ,插入这句'--font TITLE:20:"WenQuanYi Zen Hei Mono"',
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' );
Smokeping的主从模式 Master Slave
优点:
smokeping的主从结构,默认是开启master和slave所有的检测指针去检测远程主机(当然这个选项也是有个参数可以控制,只让slave去检测远程主机)。一个master可以管理多个slave,而且slave配置起来也很简单
slave从master上获取自己的配置信息,所有的检测数据以及web呈现都在master上,slave只负责按照从master获取的配置信息进 行数据检测,所以说master/slave的架构也只需要维护好master的配置文件即可,其他的信息slave都会动态获取到。
Smoking 检测分布式的检测方式是被动模式,由从节点启动时获得主节点的config 文件,然后进行数据检测收集,收集完毕后直接将数据提交给主节点。主从通信验证是通过类似于rsync的密码认证方式,在启动slave节点时指定 –shared-secret=filename 来和主进行密码验证
架构:
slave通过master的web接口与master保持正常的通信,slave在初始化启动连接到master的时候,master会告诉 slave的作业内容,当slave完成了一轮作业内容时便会将结果返回给master,如果分配给slave的任务发生了改变,master会告诉 slave,其他slave已经交付的结果
其实一个slave就是一个单独的实例,slave的配置信息来自于master,不是来自于本地配置文件(这样就减少了大量的维护成本),slave在 完成每一轮的作业任务后,就会尝试连接master提交自己的结果。如果无法连接到master,这个结果将会和下一轮的结果一块发送给 master,master收到结果后,将检测的数据存储在一个以perl的可存储形式的文件中,以便于重启了smokeping实例后,不会丢失这些数 据。
Master配置部分
配置一个主从结构,需要在master的配置文件中添加slave的部分,所有slave需要被定义在master的slave区块中(了解配置文 件中的几大区块,猛戳这里)并且每一个slave需要用户一个具有唯一名称的菜单名(层次名),对于slave所设置的章节名一定要和slave的名称保 持一致。
1.在配置文件中启用slaves块的配置,并且定义你的slave节点,如下
*** Slaves *** secrets=/usr/local/smokeping/etc/smokeping_secrets.dist # 定义通信用的秘钥文件,里面包含slave的名字以及对应密码 + tuosi # slave的名字 display_name=tuosi # slave的别名 location=changzhou # 这个字段用来定义slave主机的位置,类似于description color=0000ff # slave收集的数据在图像中显示的颜色,
2.将定义的slave节点分配给你需要监控的主机
*** Targets *** ++ changzhou # 定义一个菜单,这个值将会作为data下的一个目录名被创建,属于这个菜单下所有数据都会被存放在这个目录下 menu = 拓思机房 # 定义web上显示的菜单名 title = 拓思机房 # 定义web上显示的头部名 +++ 29gui<-(xxx.xxx.xxx.xxx.xxx) # 定义一个主机,这个主机的数据将会被存放在 data/changzhou/29gui目录下 menu = 29柜<-(xxx.xxx.xxx.xxx) # web上显示的菜单名,可点击 title = 29柜<-(xxx.xxx.xxx.xxx) # 图表头部名称 alerts = someloss # 报警阀值 slaves = tuosi # slave节点 host = xxx.xxx.xxx.xxx # 被监控的主机IP或者域名
3.创建master和slave通信的秘钥文件
创建通信用的秘钥文件,内容为“slave的名字:密码”,这里需要注意秘钥文件的权限,由于smokeping的master/slave是通过 smokeping程序进行验证的,所以这个秘钥文件的属主必须是smokeping进程的运行用户身份,并且权限为600.下面slave上的密码文件 的权限也是一样,需要同样的权限归属,这点需要注意。
# echo "tuosi:helloworld" > /usr/local/smokeping/etc/smokeping_secrets.dist # chown daemon:daemon /usr/local/smokeping/etc/smokeping_secrets.dist # chmod 600 /usr/local/smokeping/etc/smokeping_secrets.dist
Slave配置部分
slave端实际上不需要太多的配置,只需要将smokeping正确安装即可,具体可参照 Smokeping的配置安装 一文,进行到gmake install 即可~
是不是so easy~
1.创建master与slave的密码文件
# echo "helloworld" > /usr/local/smokeping/etc/secrets # chown daemon:daemon /usr/local/smokeping/etc/secrets # chmod 600 /usr/local/smokeping/etc/secrets
2.启动slave
可以使用/usr/local/smokeping/bin/smokeping --help
观察到与slave有关的几个参数如下:
--master-url # 当smokeping运行在slave模式下,使用该项指定master的访问url(web接口,用以通信)
--slave-name # 默认情况下,不指定改项时,slave连接到master后,master会以slave的hostname作为slavename,如果不希望这样做,就需要手动指定改选项
--shared-secret # 和master通信认证的密码文件
--cache-dir # 当smokeping运行在slave模式下,临时数据存放在master上的目录路径
--pid-dir # slave模式下,其pid存放的目录路径。可选参数,默认继承--cache-dir参数的值
# /usr/local/smokeping/bin/smokeping --master-url=http://xxx.xxx.xxx.xxx/smokeping.cgi --cache-dir=/usr/local/smokeping/cache/ --shared-secret=/usr/local/smokeping/etc/secrets --slave-name=tuosi --logfile=/usr/local/smokeping/slave.log
参考
http://my.oschina.net/lxcong/blog/150617
http://blog.coocla.org/293.html