Linux安全网 - Linux操作系统_Linux 命令_Linux教程_Linux黑客

会员投稿 投稿指南 本期推荐:
搜索:
您的位置: Linux安全网 > Linux监控 > 流量监控 > » 正文

你流量大吗?check_traffic.sh监控服务器流量

来源: jinga50334 分享至:

        由于公司业务的需要,领导要求对服务器的流量要进行监控。一想到流量监控,我首先想到的就是cacti(凯歌台)这个经典的开源流量监控软件。因为我知道在cacti位数众多的插件中,是有thold这样对流量有监控及报警功能的工具的。但是,由于公司目前使用的cacti版本较低,许多兼容插件是在找不着了。重新搭建的话确实会影响目前的监控工作。时间紧,得想想别的办法吧。对了不是有nagios吗!用它也能监控流量,因为以前听说过nagios有nagios-plugins,里面有插件可以监控流量。但plugins还要安装,而且配置还是费时间。后来在网上看到了石头版主用shell写的check_traffic.sh能对服务器进行流量的监控。而且不用安装任何软件,拿来就用。于是就选了这个脚本作为流量监控的工具来使用。目前这个脚本的版本是check_traffic_v1.2.2。

        操作很简单。首先将check_triffic.sh脚本拷贝到/usr/local/nagios/libexec/里面。然后在/usr/local/nagios/etc/objects/commands.cfg  文件中添加

 

  1. #######################################################################  
  2. #  
  3. #                            check_traffic  
  4. #  
  5. #######################################################################  
  6. define command{  
  7.         command_name check_traffic  
  8.         command_line $USER1$/check_traffic.sh -V 2c -C zhuzhu -H $HOSTADDRESS$ -I $ARG1$ -w $ARG2$,$ARG3$ -c $ARG4$,$ARG5$   
  9.         }  

当然这是我的command文件内容。大家可以参照网上的自行定义。但要注意单位。

默认是Kbps。

然后通过/usr/local/nagios/libexec/check_traffic.sh -V 2c -C  zhuzhu -H 192.168.0.202 -L

去确认自己要监控对象的网卡代号

List Interface for host 192.168.0.202.
Interface index 1 orresponding to  MS TCP Loopback interface
Interface index 2 orresponding to  Citrix PV Ethernet Adapt

输出信息中index后面的数字就是你要监控网卡的代号

可以自己通过命令先执行一下:

/usr/local/nagios/libexec/check_traffic.sh -V 2c -C zhuzhu -H 192.168.0.202 -I 2  -w 10,10 -c 30,30  

输出:

OK - The Traffic In is 4Kbps, Out is 0.0Kbps, Total is 4Kbps. The Check Interval is 127s |In=4Kbps;10;30;0;0 Out=0.0Kbps;10;30;0;0 Total=4Kbps;20;60;0;0 Interval=127s;1200;1800;0;0

 

V 代表snmp版本

C 代表community的名称

H 代表主机IP

I  代表网卡号

w 、c就不必说了吧

补充:10,10  30,30(代表in,out)

 

 现在编辑services.cfg

define service{
        host_name               192.168.0.202
        service_description     traffic
        check_command           check_traffic!2!10!10!30!30
        max_check_attempts      5
        normal_check_interval   3
        retry_check_interval    2
        check_period            24x7
        notification_interval   10
        notification_period     24x7
        notification_options    w,u,c,r
        contact_groups          wingroup
        }

 

然后重启nagios服务就应该齐活了。但是其实不然,我在监控公司服务器外网情况时,尤其是监控windows服务器(而且是跑了hyper-v的服务器时)。报了诸如:

SERVICE ALERT: 192.168.0.202;traffic;UNKNOWN;SOFT;1;Maybe 32 bit counter overflow, because we got a negative value here.

SERVICE ALERT: 192.168.0.202;;traffic;UNKNOWN;SOFT;3;Unknown - Read or Write File /var/tmp/check_traffic_192.168.0.202;_11.hist_dat_root__32 Error with user uid=517(nagios) gid=517(nagios) groups=517(nagios)

等报错着实废了会儿工夫排错,后来参考石头版主的方法:

如果以非nagios用户身份,手动测试执行过该脚本,请在正式使用该脚本前,删除/var/tmp下对应测试生成的/var/tmp/check_traffic_${Host}_${Interface}.hist_dat文件,否则会造成nagios用户无法读写该文件的错误。
均将问题一一解决!

然后就能看到以下信息:

 

 

 

 

check_traffic.sh非常好用,结合网上还有监控mysql的slave状态等自己写的小脚本。我不得不说开源的魅力确实太大了!!!

最后说一声,谢谢分享经验及自己劳动成果的高手们!向你们致敬!

 

 

下面有check_traffic_v1.2.2的下载链接。

 


Tags:
分享至:
最新图文资讯
1 2 3 4 5 6
验证码:点击我更换图片 理智评论文明上网,拒绝恶意谩骂 用户名:
关于我们 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 发展历史