@cdmonkey
2016-07-27T16:38:42.000000Z
字数 11836
阅读 1778
运维工具
官网:http://oss.oetiker.ch/smokeping/
Smokeping是rrdtool的作者的作品,主要是监视网络性能,其底层也是rrdtool做支持,特点是画的图非常漂亮,网络丢包和延迟用颜色和阴影来表示。它可以采用多种探测方式,包括fping、echoping、dig、curl等,以及易用的、可扩展的插件。很有特色的报警设置,不只是简单的设置一个阀值。
主从的工作方式,可以在多个节点收集同一个监测点的数据。从机会自己去检查监测点的情况(loss and rtt),并将数值提交给主机(via smokeping.cgi)。值得注意的是,从并不需要配置文件,每次从提交完数据以后,会询问主它自己的配置文件是否有变动,如果有变动,从会进行更新。
配置方法我就简单说说好了:
RTT(Round-Trip Time):简单说它是一个数据报在网络上两点中间往返一次的时间。是影响TCP性能和表征网络运行状况的重要参数。在网络中实时、准确地测量大量TCP设备和系统的RTT参数是网络管的重要环节之一。Smokeping就是这样的一个自动测试系统,它向目标设备和系统发送各种类型的测试数据包,测量、记录和展示RTT。
Median RTT:它是“中间数”而并不是平均值。Smokeping有多种类型的探针,探针在默认的设置下,每300秒向目标设备发送20个探测数据包。假如这20个数据包都返回的话,那么它就记录下这20个RTT,所以这个中间数就是第十个包的RTT。如果有五个包丢失的话,那么这个中间数就是第八个返回的包的RTT值。
Avg RTT:它是每一个测试回合中所有RTT的算术评价值。
Avg pkt loss:丢包率。
首先确认下操作系统信息:
[root@smokeping ~]# cat /etc/redhat-release
CentOS release 6.5 (Final)
--------------
[root@smokeping ~]# uname -r
2.6.32-431.el6.x86_64
#IP Address:
[root@smokeping ~]# ifconfig eth0 |awk -F '[ :]+' 'NR==2 {print $4}'
10.10.200.23
YUM Source:
#EPEL:
wget http://mirrors.ustc.edu.cn/fedora/epel/6/x86_64/epel-release-6-8.noarch.rpm
rpm -ivh epel-release-6-8.noarch.rpm
[root@smokeping ~]# rpm -qa|grep epel
epel-release-6-8.noarch
yum install -y httpd httpd-devel
#首先安装一些依赖包:
yum install -y libxml2 libxml2-devel libpng libpng-devel libjpeg libjpeg-devel \
gd gd-devel libiconv libiconv-devel glib glib-devel pango pango-devel freetype freetype-devel \
fontconfig cairo cairo-devel libart_lgpl libart_lgpl-devel popt-devel perl-ExtUtils-Embed \
libidn libidn-devel
yum install -y perl-Compress-Zlib perl-HTML-Tagset perl-HTML-Parser perl-libwww-perl \
xorg-x11-fonts-Type1 ruby libdbi
yum install -y fonts-chinese.noarch
yum install -y rrdtool-perl
这里我们选择编译安装,目的是可以指定相应的路径,方便后续查找路径使用。
[root@smokeping tools]# wget http://oss.oetiker.ch/rrdtool/pub/rrdtool-1.4.8.tar.gz
[root@smokeping tools]# tar zxvf rrdtool-1.4.8.tar.gz
[root@smokeping tools]# cd rrdtool-1.4.8
./configure --prefix=/usr/local/rrdtool --disable-tcl --disable-pytho
make && make install
--------------------
#安装后验证,出现下面的信息就说明安装成功了。安装完一定要验证,不一定安装完成后就是成功的。
[root@smokeping ~]# /usr/local/rrdtool/bin/rrdtool -v
RRDtool 1.4.8 Copyright 1997-2013 by Tobias Oetiker <tobi@oetiker.ch>
Compiled Apr 9 2015 10:41:16
Usage: rrdtool [options] command command_options
Valid commands: create, update, updatev, graph, graphv, dump, restore,
last, lastupdate, first, info, fetch, tune,
resize, xport, flushcached
RRDtool is distributed under the Terms of the GNU General
Public License Version 2. (www.gnu.org/copyleft/gpl.html)
For more information read the RRD manpages
[root@smokeping tools]# wget http://down1.chinaunix.net/distfiles/cgilib-0.5.tar.gz
[root@smokeping tools]# tar zxvf cgilib-0.5.tar.gz
[root@smokeping tools]# cd cgilib-0.5
[root@smokeping cgilib-0.5]# make
[root@smokeping cgilib-0.5]# cp libcgi.a /usr/local/lib
[root@smokeping cgilib-0.5]# cp cgi.h /usr/include
[root@smokeping ~]# yum install -y fping
#查看安装路径,方便后续填写路径:
[root@smokeping ~]# which fping
/usr/sbin/fping
wget http://jaist.dl.sourceforge.net/project/echoping/echoping/6.0.2/echoping-6.0.2.tar.gz
[root@smokeping tools]# tar zxvf echoping-6.0.2.tar.gz
[root@smokeping tools]# cd echoping-6.0.2
[root@smokeping echoping-6.0.2]# ./configure
[root@smokeping echoping-6.0.2]# make && make install
--------------------
#查看下安装路径:
[root@smokeping echoping-6.0.2]# whereis echoping
echoping: /usr/local/bin/echoping /usr/local/lib/echoping
wget http://cpan.communilink.net/authors/id/F/FL/FLORA/FCGI-0.74.tar.gz
[root@smokeping tools]# tar zxvf FCGI-0.74.tar.gz
[root@smokeping tools]# cd FCGI-0.74
[root@smokeping FCGI-0.74]# perl Makefile.PL
[root@smokeping FCGI-0.74]# make && make install
因为是通过yum安装的www服务,所以模块的安装就和基于源码编译安装的有很大的不同。
#还要安装一些必要的依赖包:
yum install -y httpd-devel libtool apr apr-devel
#下载源码包:
wget http://www.fastcgi.com/dist/mod_fastcgi-2.4.6.tar.gz
[root@smokeping tools]# tar zxvf mod_fastcgi-2.4.6.tar.gz
[root@smokeping tools]# cd mod_fastcgi-2.4.6
[root@smokeping mod_fastcgi-2.4.6]# cp Makefile.AP2 Makefile
[root@smokeping mod_fastcgi-2.4.6]# vim Makefile
#修改为下面的路径:
top_dir = /usr/lib64/httpd
[root@smokeping mod_fastcgi-2.4.6]# make && make install
--------------------
#验证一下:
[root@smokeping mod_fastcgi-2.4.6]# ls /usr/lib64/httpd/modules/|grep mod_fastcgi.so
mod_fastcgi.so
最后要加载模块:
[root@smokeping ~]# vim /etc/httpd/conf/httpd.conf
#确认有如下一行,没有则添加:
LoadModule fastcgi_module modules/mod_fastcgi.so
wget http://oss.oetiker.ch/smokeping/pub/smokeping-2.6.8.tar.gz
[root@smokeping tools]# tar zxvf smokeping-2.6.8.tar.gz
[root@smokeping tools]# cd smokeping-2.6.8
[root@smokeping smokeping-2.6.8]# ./configure --prefix=/usr/local/smokeping
#注意,这里一定会出现下面的报错信息:
** Aborting Configure ******************************
If you know where perl can find the missing modules, set
the PERL5LIB environment variable accordingly.
FIRST though, make sure that 'perl' starts the perl
binary you want to use for SmokePing.
Now you can install local copies of the missing modules
by running
./setup/build-perl-modules.sh /usr/local/smokeping/thirdparty
The RRDs perl module is part of RRDtool. Either use the rrdtool
package provided by your OS or install rrdtool from source.
If you install from source, the RRDs module is located
PREFIX/lib/perl
#直接执行脚本,接下来就是在线等,漫长的等待:
[root@smokeping smokeping-2.6.8]# ./setup/build-perl-modules.sh /usr/local/smokeping/thirdparty
#这回就没问题了。
[root@smokeping smokeping-2.6.8]# ./configure --prefix=/usr/local/smokeping
[root@smokeping smokeping-2.6.8]# /usr/bin/gmake install
#注意:这里的安装没有用过,暂且留下。
yum install -y perl perl-Net-Telnet perl-Net-DNS perl-LDAP perl-libwww-perl perl-RadiusPerl perl-IO-Socket-SSL perl-Socket6 perl-CGI-SpeedyCGI
[root@smokeping ~]# vim /usr/local/smokeping/bin/smokeping
#把第八行内容:
use lib qw(); # PERL5LIB
#修改为:
use lib qw(/usr/local/rrdtool/lib/perl/5.10.1); # PERL5LIB
只帖出要修改的部分,没有出现的不用修改。
[root@smokeping ~]# cd /usr/local/smokeping/htdocs/
[root@smokeping htdocs]# cp smokeping.fcgi.dist smokeping.fcgi
[root@smokeping htdocs]# cd ../etc/
[root@smokeping etc]# chmod 600 /usr/local/smokeping/etc/smokeping_secrets.dist
---------------------
[root@smokeping etc]# cp config.dist config
[root@smokeping etc]# vim config
#Smokeping的配置基本都在这个文件内。
*** General ***
#第一部分属于基本配置,注意下面两个与图片相关的路径设置,如果配置不对的话,打开首页时图片会显示不出来。
...
imgcache = /usr/local/smokeping/htdocs/img
imgurl = http://10.10.200.23/smokeping/img
datadir = /usr/local/smokeping/data
piddir = /usr/local/smokeping/var
cgiurl = http://10.10.200.23/smokeping/smokeping.fcgi
---------------------
*** Database ***
step = 60
pings = 20
---------------------
*** Presentation ***
charset = zh_CN.UTF-8
---------------------
*** Probes ***
+ FPing
binary = /usr/sbin/fping
---------------------
++ James
menu = James
title =James
#alerts = someloss
#slaves = boomer slave2
host = 8.8.8.8
创建目录:
[root@smokeping ~]# cd /usr/local/smokeping/
#创建下面三个目录用于保存smokeping的数据:
[root@smokeping smokeping]# mkdir cache data var
[root@smokeping smokeping]# chown apache.apache cache data var
[root@smokeping smokeping]# ln -s /usr/local/smokeping/cache /usr/local/smokeping/htdocs/cache
---------------------
[root@smokeping smokeping]# mkdir htdocs/img
[root@smokeping smokeping]# chown apache.apache htdocs/img/
修改配置文件:
[root@smokeping ~]# vim /etc/httpd/conf/httpd.conf
#找到下面这行,去掉注释,并修改为:
ServerName localhost:80
#找到下面这行,去掉注释:
AddHandler cgi-script .cgi
---------------------
#在配置文件最后面添加如下内容:
Alias /smokeping/ "/usr/local/smokeping/htdocs/"
<Directory "/usr/local/smokeping/">
AllowOverride None
Options All
AddHandler cgi-script .fcgi .cgi
Order allow,deny
Allow from all
DirectoryIndex smokeping.fcgi
</Directory>
创建启动脚本:
[root@smokeping ~]# mv smokeping.sh /etc/init.d/smokeping
[root@smokeping ~]# chmod 755 /etc/init.d/smokeping
#注意脚本格式,要不然会报“没有那个文件或目录”的错误信息。
[root@smokeping ~]# dos2unix /etc/init.d/smokeping /etc/init.d/smokeping
最后,启动服务并设置必要服务开机启动。
#开启服务之前,可以对配置文件进行检查:
[root@smokeping ~]# /usr/local/smokeping/bin/smokeping --check
Configuration file '/usr/local/smokeping/bin/../etc/config' syntax OK.
---------------------
[root@smokeping ~]# chkconfig smokeping on
[root@smokeping ~]# chkconfig httpd on
[root@smokeping ~]# /etc/init.d/smokeping start
Starting Smokeping: [ OK ]
[root@smokeping ~]# /etc/init.d/httpd start
Starting httpd: [ OK ]
至此,我们就可以通过浏览器打开监控页面进行监控了。
#第一步,创建用户
[root@smokeping ~]# htpasswd -cb /usr/local/smokeping/etc/htpasswd.users admin admin
Adding password for user admin
[root@smokeping ~]# ll /usr/local/smokeping/etc/htpasswd.users
-rw-r--r--. 1 root root 20 4月 9 17:18 /usr/local/smokeping/etc/htpasswd.users
#第二步,修改配置文件(修改定义站点目录的那部分)
[root@smokeping ~]# vim /etc/httpd/conf/httpd.conf
Alias /smokeping/ "/usr/local/smokeping/htdocs/"
<Directory "/usr/local/smokeping/">
AllowOverride None
Options All
AddHandler cgi-script .fcgi .cgi
Order allow,deny
Allow from all
DirectoryIndex smokeping.fcgi
#添加下面这四行指令:
AuthName "Smokeping Access"
AuthType Basic
AuthUserFile /usr/local/smokeping/etc/htpasswd.users
Require valid-user
</Directory>
---------------------
#最后要重启服务:
[root@smokeping ~]# /etc/init.d/httpd restart
Stopping httpd: [ OK ]
Starting httpd: [ OK ]
那么如何修添加用户以及改用户的密码呢?(详细用法)
#如何在原有密码文件中增加下一个用户:
[root@smokeping ~]# htpasswd -b /usr/local/smokeping/etc/htpasswd.users cdmonkey cdmonkey
Adding password for user cdmonkey
[root@smokeping ~]# cat /usr/local/smokeping/etc/htpasswd.users
admin:25SPfMgnV8K12
cdmonkey:iUfdOiqd7O.fo
#修改用户密码,即先删除指定用户,再添加用户命令创建用户即可实现修改密码的功能:
[root@smokeping ~]# htpasswd -D /usr/local/smokeping/etc/htpasswd.users admin
Deleting password for user admin
[root@smokeping ~]# htpasswd -b /usr/local/smokeping/etc/htpasswd.users admin suixingpay.123
Adding password for user admin
配置文件详解:http://blog.chinaunix.net/uid-23886490-id-3135554.html
*** General ***
#第一部分属于基本配置。
owner = cdmonkey
contact = wang_hz@suixingpay.com
mailhost = my.mail.host
sendmail = /usr/sbin/sendmail
# NOTE: do not put the Image Cache below cgi-bin
# since all files under cgi-bin will be executed ... this is not
# good for images.
imgcache = /usr/local/smokeping/htdocs/img
imgurl = http://10.10.200.23/smokeping/img
datadir = /usr/local/smokeping/data
piddir = /usr/local/smokeping/var
cgiurl = http://10.10.200.23/smokeping/smokeping.fcgi
smokemail = /usr/local/smokeping/etc/smokemail.dist
tmail = /usr/local/smokeping/etc/tmail.dist
# specify this to get syslog logging
syslogfacility = local0
# each probe is now run in its own process
# disable this to revert to the old behaviour
# concurrentprobes = no
*** Alerts ***
#第二部分是属于报警配置。
to = wang_hz@suixingpay.com
from = smokealert@company.xy
+someloss
type = loss
# in percent
pattern = >0%,*12*,>0%,*12*,>0%
comment = loss 3 times in a row
*** Database ***
#第三部分是RRD数据库的配置。
#注意下面这两个参数要在启动服务之前配置好,如果在服务启动后再配置这两个参数,需要把原来的rrd文件都删除,然后再启动服务才可以,所以这个一定要先配置好。
#这里显示的就是其默认数值,表示每300s内执行20次ping的动作。
step = 300
pings = 20
# consfn mrhb steps total
AVERAGE 0.5 1 1008
AVERAGE 0.5 12 4320
MIN 0.5 12 4320
MAX 0.5 12 4320
AVERAGE 0.5 144 720
MAX 0.5 144 720
MIN 0.5 144 720
*** Presentation ***
#第四部分是关于网络状态的一些配置和解释,基本不需要更改。
template = /usr/local/smokeping/etc/basepage.html.dist
+ charts
menu = Charts
title = The most interesting destinations
++ stddev
sorter = StdDev(entries=>4)
title = Top Standard Deviation
menu = Std Deviation
format = Standard Deviation %f
++ max
sorter = Max(entries=>5)
title = Top Max Roundtrip Time
menu = by Max
format = Max Roundtrip Time %f seconds
++ loss
sorter = Loss(entries=>5)
title = Top Packet Loss
menu = Loss
format = Packets Lost %f
++ median
sorter = Median(entries=>5)
title = Top Median Roundtrip Time
menu = by Median
format = Median RTT %f seconds
#下面的两个模块(overview & detail)里面是图片大小设置,可以按需来设置。
+ overview
width = 600
height = 50
range = 10h
+ detail
width = 600
height = 200
unison_tolerance = 2
"Last 3 Hours" 3h
"Last 30 Hours" 30h
"Last 10 Days" 10d
"Last 400 Days" 400d
+ hierarchies
++ owner
title = Host Owner
++ location
title = Location
*** Probes ***
+ FPing
#第五部分是探针的配置,我们一般只用到fping,所以就只要以下配置就可以了,确定路径是否正确(这里还可以设置数据包的大小)。
binary = /usr/sbin/fping
#*** Slaves ***
#第六分部是主从关系里面的从服务器相关配置。
#secrets=/usr/local/smokeping/etc/smokeping_secrets.dist
#+boomer
#display_name=boomer
#color=0000ff
#+slave2
#display_name=another
#color=00ff00
*** Targets ***
#第七部分是监控节点目标的配置。在这里可以单独配置一台服务器的监控情况,需要从服务器上取值的配置也是在这里配置。
#需要注意一下:+代表一级菜单,+下面的++是继承上面的+成为二级菜单。而且可以有多个一级菜单和二级菜单。
probe = FPing
menu = Top
title = Network Latency Grapher
remark = Welcome to the SmokePing website of xxx Company. \
Here you will learn all about the latency of our network.
+ Test
menu= Targets
#parents = owner:/Test/James location:/
++ James
menu = James
title =James
#alerts = someloss
#slaves = boomer slave2
host = 8.8.8.8
++ MultiHost #在这里设置在一张图里画多个监测点的数值。
menu = Multihost
title = James and James as seen from Boomer
host = /Test/James /Test/James~boomer
验证配置文件:
[root@smokeping ~]# /usr/local/smokeping/bin/smokeping --check
Configuration file '/usr/local/smokeping/bin/../etc/config' syntax OK.