Linux SNMP命令讲解和应用实例
再对Linux SNMP的不断学习中,它的一些命令设置一直是我们强调的重点内容。所以我们再来把相关的一些命令程序进行一下复习。今天将介绍Linux SNMP问题的解决方法RRD数据库更新实例。update 命令:它使用1个或多个参数,其格式为: : . 如果你知道可以用一个 N 表示当前的时间,你一定会高兴的。或者你可以用Perl中的 time 函数来指定时间:perl: perl -e ‘print time, “\n” ‘shell: date +%s如何按照固定间隔运行某个程序各操作系统不同。不过可以用伪码来表示:- Get the value and put it in variable “$speed”- rrdtool update speed.rrd N:$speed 就这些。每5分钟运行一次上面的脚本。在你想知道图像看起来是啥样时,运行上面的例子。你可以把他们放入一个脚本中。运行此脚本后,查看我们刚才创建的graph。
Linux SNMP相关知识
我可以想像到只有少数的人能够每5分钟从他们的汽车中读取一次真实的数据。其他人不得不清算其他类型的计数器。你可以测量打印机打印的页数,咖啡机做的咖 啡杯数,计算使用的电流的设备,都可以。
递增的计数器可以被监视,并且用你已经学会的方法被绘制成图像。稍后我们就能够监视像温度计这样的值了。大多数对RRDtool感兴趣的人会使用一个跟踪网络设备传输数据量的计数器。这样我们下一步就来作这个。我们会从解释如何收集数据开始。
有些人会说有些工具可以帮助你收集数据。他们是对的!不过,我感觉理解这些工具不是必须的非常重要。在你能够确定为什么事情发生了错误,你要知道他们是如何工作的。本例中使用的工具在本文档前面非常简短地提到过,它就是所谓的Linux SNMP。它是与联网设备交谈的方式。下面用到的工具名为 Linux SNMPget ,以下是关于它是如何工作的说明:
Linux SNMPget device password OID或Linux SNMPget -v[version] -c[password] device OID对于device, 你要用设备的名称或者IP地址来替换。对于password, 你需要使用Linux SNMP领域中称为 comunity read string 来替换。
对于某些设备来说,缺省的 public 可以工作,但是该设置可能会被关闭,调整或者由于安全和机密的原因而被保护起来。请阅读你的设备或程序的文档。 接下来有一个称为OID的参数,它用来表示 对象标识符 。
刚开始学习Linux SNMP时,它看起来有些令人困惑。在你看到MIB管理信息基时,就不会那么困难了。MIB是用来描述数据的倒状树,它有只有一个根结 点,并且由根结点开始有多个分支。这些分支都以另一个结点终结,他们继续向下分支,如此继续。
所以的分支都有一个名称,它们构成了一个我们能够沿着往下的 路径。我们所沿着的这些分支都被命名了:iso, org, dod, internet, mgmt 和mib-2.这些名称也可以用数字方式记录,就像 1 3 6 1 2 1。
iso.org.dod.internet.mgmt.mib-2 (1.3.6.1.2.1) 有些程序会使用前导点 . , 令人感到许多困惑。在一个OID中并 没有前导点。为了显示OID缩记法和OID完整记法的区别,(通常约定)在使用OID的完整记法时使用前导点。
通常这些程序在返回数据给你时,会省略却缺 省的部分。这些程序有的有几个缺省前缀,这会让事情显得更加糟糕。Ok, lets continue to the start of our OID: we had 1.3.6.1.2.1 From there, we are especially interested in the branch interfaces which has number 2 (e.g., 1.3.6.1.2.1.2 or 1.3.6.1.2.1.interfaces).
好了,我们继续OID的初步学习:我们有一个1.3.6.1.2.1的OID,我们对(其下面的) interface 分支特别感兴趣,其编号为2(例如:1.3.6.1.2.1.2 或 1.3.6.1.2.1.interface)。
首先,我们得要有几个Linux SNMP的程序。先看看你的OS平台上是否有已编译好的软件包。这是最便捷的方式。如果没有,你就得下载源代码、并编译。互联网上到处都是源代码、程序。你可以用你喜欢的任何方式、搜索引擎来找到相关的信息。
假设你已经有了这些程序。先试着收集大多数系统都有的数据。记住:那些引起我们兴趣的树,它上面的部分都有一个简略名。在此我会给出一个在Fedora Core 3操作系统上可用的例子。如果对你的操作系统不可用,请查看Linux SNMP的手册,并作相应的调整让它能够运行。
Linux SNMPget -v2c -c public myrouter system.sysDescr.0该设备应当回应其自身的描述,该描述可能是一个空的。只有在你从某个设备获得响应后,你才能够继续。其中可能需要使用不同的口令、或者不同的设备。
Linux SNMPget -v2c -c public myrouter interfaces.ifNumber.0最好你得到的结果是一个数字。如果这样的话,你就可以继续往下,并试试另一个叫做 Linux SNMPwalk 的程序。Linux SNMPwalk -v2c -c public myrouter interfaces.ifTable.ifEntry.ifDescr如果该命令返回一系列的接口,这就对了。以下是该命令运行的返回结果的例子:
[user@host /home/alex]$ Linux SNMPwalk -v2c -c public cisco 2.2.1.2 interfaces.ifTable.ifEntry.ifDescr.1 = "BRI0: B-Channel 1" interfaces.ifTable.ifEntry.ifDescr.2 = "BRI0: B-Channel 2" interfaces.ifTable.ifEntry.ifDescr.3 = "BRI0" Hex: 42 52 49 30 interfaces.ifTable.ifEntry.ifDescr.4 = "Ethernet0" interfaces.ifTable.ifEntry.ifDescr.5 = "Loopback0" 对于cisco设备,我想监视 ‘Ethernet0` 接口,从上面的输出结果能够看到该接口的编号是 4。
我试着运行如下命令:[user@host /home/alex]$ Linux SNMPget -v2c -c public cisco 2.2.1.10.4 2.2.1.16.4
interfaces.ifTable.ifEntry.ifInOctets.4 = 2290729126 interfaces.ifTable.ifEntry.ifOutOctets.4 = 1256486519 这样,我就有两个OID需要监视,他们是(这次使用完整记法):1.3.6.1.2.1.2.2.1.10和1.3.6.1.2.1.2.2.1.16这两个OID都有接口编号4。
别被糊弄了,我可不是试一次就搞定的。我花了一些数据来搞清这些数字都是什么意思。把这些编号转换成描述文字大有帮助… 至少在大家谈论MIB和OID时,你知道他们是什么东西。别忘了接口编号(如果它不是附属接口,就是0),如果用Linux SNMPget没有得到响应,试试 Linux SNMPwalk。
应用RRDtool的实例
实际运用的例子开始有趣的东东吧。首先,创建一个新的数据库。它包含输入和输出2个计数器的数据。该数据被放入能够进行平均的归档中。他们一次使用1、6、24、或 288个样本。他们同时被存入保存最大数字的归档中。稍后会解释。样本间隔时间为300秒,也就是5分钟,这是一个好的开始。:
1个样本 “平均” 保留5分钟的周期 6个样本 每30分钟进行一次平均 24个样本 每2小时进行一次平均 288个样本 每1天进行一次平均 我们试着与MRTG互相兼容,MRTG存储以下数据::
600 5分钟样本数: 2天和2小时 600 30分钟样本数: 12.5天 600 2小时样本数: 50天 732 1天样本数: 732天 这些范围被补充进去,因此在数据库中保存的数据总数大约797天。RRDtool存储不同的数据,它不会在 每日 归档停止的地方开始 每周 归档。对于这两个归档,最新的数据会是在 now 附近,因此我们需要比MRTG保存更多的数据!我们需要::
600个5分钟的样本 (2天和2小时) 700个30分钟的样本 (2天和2小时,加12.5天) 775个2小时的样本 (上述+50天) 797个1天的样本 (上述+732天,环型回绕最大797) rrdtool create myrouter.rrd \ DS:input:COUNTER:600:U:U \ DS:output:COUNTER:600:U:U \ RRA:AVERAGE:0.5:1:600 \ RRA:AVERAGE:0.5:6:700 \ RRA:AVERAGE:0.5:24:775 \ RRA:AVERAGE:0.5:288:797 \ RRA:MAX:0.5:1:600 \ RRA:MAX:0.5:6:700 \ RRA:MAX:0.5:24:775 \ RRA:MAX:0.5:288:797
接下来要做的就是收集数据并把它保存起来。以下是一个例子。它是用伪码写的,你得根据OS调整后让它能够运行。: