Smokeping 主要是监视网络性能,包括常规的 ping,用 echoping 监视 www 服务器性能,监视 dns 查询性能,监视 ssh 性能等。底层也是 rrdtool 做支持,特点是画的图非常漂亮,网络丢包和延迟用颜色和阴影来表示。下面我们来开始安装Smokeping
1
|
rpm -Uvh http:
//apt
.sw.be
/redhat/el6/en/x86_64/rpmforge/RPMS/rpmforge-release-0
.5.3-1.el6.rf.x86_64.rpm
|
1
|
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
|
1
|
yum -y
install
perl-ExtUtils-MakeMaker perl-RRD-Simple rrdtool rrdtool-perl curl fping echoping gcc
make
wget libxml2-devel libpng-devel glib pango
|
1
|
yum -y
install
pango-devel freetype freetype-devel fontconfig cairo cairo-devel libart_lgpl libart_lgpl-devel mod_fastcgi
screen
|
1
2
3
4
|
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的模块,所以运行下面内容即可
1
|
.
/setup/build-perl-modules
.sh
/usr/local/smokeping/thirdparty
|
继续运行
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
.
/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"
这一行之下添加如下内容: 用#号注释掉的是验证部分 可有可无
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
Alias
/cache
"/usr/local/smokeping/cache/"
Alias
/cropper
"/usr/local/smokeping/htdocs/cropper/"
Alias
/smokeping
"/usr/local/smokeping/htdocs/smokeping.fcgi"
<Directory
"/usr/local/smokeping"
>
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
<
/Directory
>
|
如果要启用验证,那取消#号
进入
1
|
cd
/usr/local/smokeping/htdocs
|
目录, 执行命令:
1
2
3
4
5
6
7
|
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"',
1
2
3
4
5
6
7
|
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节点,如下
1
2
3
4
5
6
7
|
*** 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节点分配给你需要监控的主机
1
2
3
4
5
6
7
8
9
10
11
12
|
*** 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上的密码文件 的权限也是一样,需要同样的权限归属,这点需要注意。
1
2
3
|
# 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的密码文件
1
2
3
|
# 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参数的值
1
2
3
4
5
|
# /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
本文转自flyingzf 51CTO博客,原文链接:http://blog.51cto.com/flyingzf/1557702,如需转载请自行联系原作者