Chinaunix首页 | 论坛 | 博客
  • 博客访问: 292844
  • 博文数量: 84
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: -10
  • 用 户 组: 普通用户
  • 注册时间: 2016-07-05 09:11
文章分类
文章存档

2015年(1)

2014年(6)

2013年(8)

2012年(1)

2011年(6)

2010年(2)

2009年(16)

2008年(44)

我的朋友

分类: LINUX

2014-02-03 15:12:12

                                                             Cacti自定义OID制图

系统环境

监控主机:5.5(32bit) Nginx平台 Cacti0.87g   net-snmp5.3.2  192.168.93.135

被监控机:Centos5.5(32bit)  net-snmp5.3.2  192.168.93.134

Cacti的安装参考:

CentOS 5.5完整安装Cacti+Spine 

CentOS快速安装Cacti 

一、在被监控机编写一个脚本,想监控什么就写什么吧,我这里只写了一个输出随机数的简单脚本,实验麻,嘻嘻:

#!/bin/bash

echo $RANDOM


二、然后让snmpd可以获到脚本的输出

大家都知道Cacti是通过snmp获取数值的,那么我们在snmpd.conf里添加我们自己写的脚本:

exec .1.3.6.1.4.1.2021.1 test /root/test.sh


这行配置是什么意思呢,我们切开来说明:

exec 就不用说了吧,一个执行函数,好像php执行linux命令一样

.1.3.6.1.4.1.2021.1 这是一个自定义的snmp OID,可以这样理解吧.1.3.6.1.4.1.2021这一段是固定的,已经被一些组织注册的,后面的可以自己使用,前提是要确认这个OID没有被其它程序占用,可以测试一下,例如:

 [root@localhost www]# /usr/local/net-snmp/bin/snmpwalk -c public -v 2c 192.168.93.134 .1.3.6.1.4.1.2021.2
UCD-SNMP-MIB::prIndex.1 = INTEGER: 1
UCD-SNMP-MIB::prIndex.2 = INTEGER: 2
UCD-SNMP-MIB::prIndex.3 = INTEGER: 3
UCD-SNMP-MIB::prNames.1 = STRING: mountd
UCD-SNMP-MIB::prNames.2 = STRING: ntalkd
UCD-SNMP-MIB::prNames.3 = STRING: sendmail
UCD-SNMP-MIB::prMin.1 = INTEGER: 0
UCD-SNMP-MIB::prMin.2 = INTEGER: 0
UCD-SNMP-MIB::prMin.3 = INTEGER: 1
UCD-SNMP-MIB::prMax.1 = INTEGER: 0
UCD-SNMP-MIB::prMax.2 = INTEGER: 4
UCD-SNMP-MIB::prMax.3 = INTEGER: 10
UCD-SNMP-MIB::prCount.1 = INTEGER: 0
UCD-SNMP-MIB::prCount.2 = INTEGER: 0
UCD-SNMP-MIB::prCount.3 = INTEGER: 0
UCD-SNMP-MIB::prErrorFlag.1 = INTEGER: 1
UCD-SNMP-MIB::prErrorFlag.2 = INTEGER: 0
UCD-SNMP-MIB::prErrorFlag.3 = INTEGER: 1
UCD-SNMP-MIB::prErrMessage.1 = STRING: No mountd process running.
UCD-SNMP-MIB::prErrMessage.2 = STRING: 
UCD-SNMP-MIB::prErrMessage.3 = STRING: Too few sendmail running (# = 0)
UCD-SNMP-MIB::prErrFix.1 = INTEGER: 0
UCD-SNMP-MIB::prErrFix.2 = INTEGER: 0
UCD-SNMP-MIB::prErrFix.3 = INTEGER: 0
UCD-SNMP-MIB::prErrFixCmd.1 = STRING: 
UCD-SNMP-MIB::prErrFixCmd.2 = STRING: 
UCD-SNMP-MIB::prErrFixCmd.3 = STRING: 

 


这样说明.1.3.6.1.4.1.2021.2 已经有程序在用了,再看看下一个:

 [root@localhost www]# /usr/local/net-snmp/bin/snmpwalk -c public -v 2c 192.168.93.134 .1.3.6.1.4.1.2021.3
UCD-SNMP-MIB::ucdavis.3 = No Such Object available on this agent at this OID

如果看见这样的信息,那么恭喜,这个OID可以使用

接着看:

test 是一个名称而已

 /root/test.sh 刚才写的脚本的绝对路径,后面可以接参数的

然后重启snmpd

我们回到主监控机(192.168.93.135)上,用snmpwalk命令测试获取被监控机上刚才定义的OID数据:

[root@localhost www]# /usr/local/net-snmp/bin/snmpwalk -c public -v 2c 192.168.93.134 .1.3.6.1.4.1.2021.1
UCD-SNMP-MIB::ucdavis.1.1.1 = INTEGER: 1
UCD-SNMP-MIB::ucdavis.1.2.1 = STRING: "test"
UCD-SNMP-MIB::ucdavis.1.3.1 = STRING: "/root/test.sh"
UCD-SNMP-MIB::ucdavis.1.100.1 = INTEGER: 0
UCD-SNMP-MIB::ucdavis.1.101.1 = STRING: "27230"
UCD-SNMP-MIB::ucdavis.1.102.1 = INTEGER: 0
UCD-SNMP-MIB::ucdavis.1.103.1 = ""


命令后面那一串OID就是刚才在被监控机上snmpd.conf中配置的OID,很明显UCD-SNMP-MIB::ucdavis.1.101.1 = STRING: "27230" 这一段是我们需要的数据,然后再进一步精确获取出来,看见我标的蓝色字体的数字吧,这是它的准确OID,把这段数字加在原本的OID后面,再来获取一次看看:

 [root@localhost www]# /usr/local/net-snmp/bin/snmpwalk -c public -v 2c 192.168.93.134 .1.3.6.1.4.1.2021.1.101.1
UCD-SNMP-MIB::ucdavis.1.101.1 = STRING: "12995"

这样我们就可以准确获取到我们想要的数据了,记住这串OID,下面我们就要从cacti里生成数据源和制图了
 

三、生成数据源

在cacti界面中console->Templates->Data Templates,然后点击右上角的Add,如下图

Templates中的name是给这个数据模板的命名,Data Source中的name将来显示在Data Sources中,我这里添加“|host_description| – Random. – ESTBLISHED”,选get snmp data,Internal Data Source Name也可以随便添,这个用来给rrd文件命名,设置完之后点击create,然后下面会多出一些选项,我们只需填写一项就可以,就是OID那一项,把我们上面记下来的OID填写进去:

然后就可以保存!

四、下面添加模板制图

在cacti界面中console->Templates->Graph Templates,然后点击右上角的Add,如下图:

…………

Graph Template中的name是将来显示在图片上面中间的内容,我这里添加"|host_description| – Tcp Conn. –ESTBLISHED",然后create,上面会多出一些选项,Graph Template Items 这里就是让我们添加数据源,就好像之前做数据叠加那样,我们把之前的数据添加进去:

下图是添加数据源

下图是添加图下面的统计数中的current的

下图是添加图下面的统计数中的average的

下图是添加图下面的统计数中的max的

添加完后如下图:

这样就可以保存了!

五、把模板添加进去被监控机里

New Graphs中选择主机然后在Graph Templates中的下拉表拉选我们添加的模板,点击create就完成了

 

最后的效果图如下:


哈哈,看到图了~~~~

阅读(2768) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~