使用MRTG画图进行监控

   MRTG通常认为是一个性能监控工具,有着很长的使用历史,很多网管都使用它来对系统进行监控。实际上,它真正的作用是一个画图工具。它可以接受一些数值参数,并根据这些值构建一个二维图形以供监控使用。最常见的就是获取设备的snmp信息,例如网络流量,然后生成图形。还可以从脚本得到CPU、Disk I/O、内存的数据,而呈现直观的图形。
   虽然其功能有限,而且已经逐步被rrdtool代替。但因为大部分发行版都自带MRTG软件包,使用也非常简单,所以,在小范围的网络环境中,还是有其用武之地的。
   为方便说明,我先以一个最简单的例子:从snmp获取网络流量,使用MRTG显示为例来说明。及后再补充从其他方式获取数据的方式。
一、系统平台
以红旗DC Server 5.0为例:

# rpm -qa|grep mrtg
mrtg-2.10.15-1


此外,为从设备得到网络数据,最简单的方式就是从snmp获取信息。还有,mrtg会生成png文件,并需要放到web上显示,所以,最少需要有如下的支持包:

引用
net-snmp gd-1.8.4-4 gd-devel-1.8.4-4 perl-5.6.0-17 perl-CGI mod_perl-1.24_01-3 libpng-1.0.12-2 libpng-devel-1.0.12-2  httpd(apache)


包括但不限于以上版本和文件。

二、打开SNMP权限
是否打开SNMP服务,并不是MRTG使用的条件。从SNMP获取设备信息是比较方便而标准的办法。
Linux下通常就是使用net-snmp(原称ucd-snmp),默认情况,其提供一个public的community供使用,但并没有打开允许接入的权限。
snmp的agent配置文件在:/etc/snmp/snmpd.conf
1、允许mib2库读取信息
修改:

引用
#       group          context sec.model sec.level prefix read   write  notif
access  notConfigGroup ""      any       noauth    exact  systemview none none


为:

引用
#       group          context sec.model sec.level prefix read   write  notif
access  notConfigGroup ""      any       noauth    exact   mib2 none none


2、使snmp信息通过mib2库显示
修改:

引用
#view mib2   included  .iso.org.dod.internet.mgmt.mib-2 fc


为:

引用
view mib2   included  .iso.org.dod.internet.mgmt.mib-2 fc


3、修改标识
把:

引用
syslocation Unknown (edit /etc/snmp/snmpd.conf)
syscontact Root <root@localhost> (configure /etc/snmp/snmp.local.conf)


修改为可标识该主机的信息:

引用
syslocation PrintServer
syscontact Root <root@localhost>


MRTG可以读到该信息的。

4、启动snmpd服务

# service snmpd start


校验:

引用
# netstat -ln|grep 199
tcp        0      0 0.0.0.0:199                 0.0.0.0:*                   LISTEN


三、配置MRTG
MRTG分如下两部分:

引用
a)工作目录,存放图形数据,供httpd显示
b)配置文件


1、创建工作目录

# mkdir /var/www/html/mrtg


存在于/var/www/mrtg目录可以不用理会。

2、生成配置文件
在/etc/mrtg目录有一个mrtg.cfg文件,但太简单,我们需要重新生成一个。

# cfgmaker --output=/etc/mrtg/mailmrtg.cfg public@192.168.228.153


其中,public是snmp的community,192.168.228.153是其对应的主机IP地址。

3、设定全局参数
上述命令会通过snmp搜索主机上所有的网络,并自动生成对应的参数。可根据实际情况排除不必要的网络接口,例如:sit0、lo等,然后修改剩余的标识。

# vi mailmrtg.cfg


设定工作目录:

引用
WorkDir: /var/www/html/mrtg


4、设定网络标识
以其中一个网卡为例:

引用
Target[192.168.228.153_2]: 2:public@192.168.228.153:
SetEnv[192.168.228.153_2]: MRTG_INT_IP="192.168.228.153" MRTG_INT_DESCR="bond0"
MaxBytes[192.168.228.153_2]: 12500000
Title[192.168.228.153_2]: Traffic Analysis for 2 -- printserver
PageTop[192.168.228.153_2]: <H1>Traffic Analysis for 2 -- printserver</H1>
<TABLE>
  <TR><TD>System:</TD>     <TD>printserver in Unknown (edit /etc/snmp/snmpd.conf)</TD></TR>
  <TR><TD>Maintainer:</TD> <TD>Root &lt;root@localhost&gt; (configure /etc/snmp/snmp.local.conf)</TD></TR>
  <TR><TD>Description:</TD><TD>bond0  </TD></TR>
  <TR><TD>ifType:</TD>     <TD>ethernetCsmacd (6)</TD></TR>
  <TR><TD>ifName:</TD>     <TD></TD></TR>
  <TR><TD>Max Speed:</TD>  <TD>12.5 MBytes/s</TD></TR>
  <TR><TD>Ip:</TD>         <TD>192.168.228.153 (printserver)</TD></TR>
</TABLE>


其中:

引用
[192.168.228.153_2]:是一个关键标识,属于该标识的都属于同一组;
2:public@192.168.228.153:是从那里获取snmp信息,前面的2用于区分多个网卡设备,与snmp端相同;
SetEnv:是从snmp获取网络信息的参数;
MaxBytes:标识图中最大的纵向数据值;
Title:图的标题
PageTop:详细内容


修改为:

引用
Target[192.168.228.153_2]: 2:public@192.168.228.153:
SetEnv[192.168.228.153_2]: MRTG_INT_IP="192.168.228.153" MRTG_INT_DESCR="bond0"
MaxBytes[192.168.228.153_2]: 12500000
Title[192.168.228.153_2]: Traffic Analysis for bond0 -- printserver
PageTop[192.168.228.153_2]: <H1>Traffic Analysis for bond0 -- printserver</H1>
<TABLE>
  <TR><TD>System:</TD>     <TD>PrintServer in RedFlag DC Server 5.0</TD></TR>
  <TR><TD>Maintainer:</TD> <TD>Root &lt;root@localhost&gt;</TD></TR>
  <TR><TD>Description:</TD><TD>bond0  </TD></TR>
  <TR><TD>ifType:</TD>     <TD>ethernetCsmacd (6)</TD></TR>
  <TR><TD>ifName:</TD>     <TD></TD></TR>
  <TR><TD>Max Speed:</TD>  <TD>12.5 MBytes/s</TD></TR>
  <TR><TD>Ip:</TD>         <TD>192.168.228.153 (printserver)</TD></TR>
</TABLE>


其余的网卡可注释,或删除,或参考配置。

5、生成index.html

# indexmaker --output=/var/www/html/mrtg/index.html --title=PrintServer /etc/mrtg/mailmrtg.cfg


6、由数据生成图表

# mrtg /etc/mrtg/mailmrtg.cfg


※注:由于开始没有旧的日志数据,所以前两次会报警告:

引用
Rateup WARNING: /usr/bin//rateup could not read the primary log file for 192.168.228.153_2
Rateup WARNING: /usr/bin//rateup The backup log file for 192.168.228.153_2 was invalid as well


当再运行两次后即会正常。若出现Error信息,请重新查看前面的配置是否有误!

7、修改默认httpd的mrtg配置
修改/etc/httpd/conf.d/mrtg.conf为:

引用
Alias /mrtg /var/www/html/mrtg

<Location /mrtg>
   Order deny,allow
   #Deny from all
   #Allow from 127.0.0.1
   #Allow from ::1
   # Allow from .example.com
    Allow from all
</Location>


重启httpd服务:

# service httpd restart


※注:仅用于说明演示,并没有考虑太多的权限问题,请自行解决。

8、查看输出页面

引用
http://ip/mrtg/




9、加入计划任务
若一切正常,则把mrtg命令加入计划任务即可。
在/etc/cron.d/mrtg加入:

引用
*/5 * * * * root /usr/bin/mrtg /etc/mrtg/mailmrtg.cfg --lock-file /var/lock/mrtg/mrtg_l --confcache-file /var/lib/mrtg/mrtg.ok


表示每5分钟执行一次。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值