扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
2010年7月6日
关键字: 网络
在学习Linux SNMP协议的相关知识中,我们已经发现,这个过程是非常复杂的。所以我们来对这个协议进行一下具体的讲解并分析一个实际的应用例子。
对于Linux SNMP协议应用我们本文将为大家例举一个具体的例子帮助大家掌握这部分内容?那么对于这个复杂的过程我们在前面的文章中已经介绍过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如果该命令返回一系列的接口,这就对了?以下是该命令运行的返回结果的例子:
编辑推荐
TCP/IP协议专题
TCP/IP(传输入控制地议/网际协议)是一种网络通信协议,它规范了网络上的所有通信设备,尤其是一个主机与..
[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?
Linux SNMP协议应用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调整后让它能够运行?:
while not the end of the universe do get result of Linux SNMPget router community 2.2.1.10.4 into variable $in get result of Linux SNMPget router community 2.2.1.16.4 into variable $out rrdtool update myrouter.rrd N:$in:$out wait for 5 minutes done 在收集了1天的数据后,试着用下面的命令创建图像::
rrdtool graph myrouter-day.png --start -86400 \\ DEF:inoctets=myrouter.rrd:input:AVERAGE \\ DEF:outoctets=myrouter.rrd:output:AVERAGE \\ AREA:inoctets#00FF00:"In traffic" \\ LINE1:outoctets#0000FF:"Out traffic" 这会产生一个具有1天流量值的图像?1天有24(小时)x60(分钟)x60(秒)?我们从当前时间-86400秒开始?我们用DEF把输入和输出字节数定义成myrouter.rrd数据库中的的平均值,并且绘制输入流量区和输出流量线?
如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。