CentOS6 安装配置Smokeping

  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" 
"/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,如需转载请自行联系原作者




你可能感兴趣的:(CentOS6 安装配置Smokeping)