当我在OID(1.3.6.1.4.1.2021.4)上使用snmpwalk时,我得到以下结果:
UCD-SNMP-MIB::memIndex.0 = INTEGER: 0
UCD-SNMP-MIB::memErrorName.0 = STRING: swap
UCD-SNMP-MIB::memMinimumSwap.0 = INTEGER: 16000 kB
但是,当我使用pysnmp模块查询相同的OID时,我得到的结果如下:
(ObjectName(1.3.6.1.4.1.2021.4.1.0), Integer(0))
(ObjectName(1.3.6.1.4.1.2021.4.2.0), OctetString('swap'))
(ObjectName(1.3.6.1.4.1.2021.4.12.0), Integer(16000))
我已将pysnmp_mibs放在os.environ中,而我正在使用的代码是:
from pysnmp.entity.rfc3413.oneliner import cmdgen
from pysnmp.smi import builder, view, error
errorIndication, errorStatus, errorIndex, \
varBindTable = cmdGen.nextCmd (
cmdgen.CommunityData('test-agent', 'public'),
cmdgen.UdpTransportTarget ( (localhost, 161) ),
('1.3.6.1.4.1.2021.4')
)
if errorIndication:
log.warn(errorIndication)
return
else:
if errorStatus:
log.warn( '%s at %s\n' % (
errorStatus.prettyPrint (),
errorIndex and varBindTable[-1][int (errorIndex) - 1] or '?'
))
return
else:
for varBindTableRow in varBindTable:
for oid, val in varBindTableRow:
(symName, modName), indices = cmdgen.mibvar.oidToMibName(
cmdGen.mibViewController, oid
)
val = cmdgen.mibvar.cloneFromMibValue(
cmdGen.mibViewController, modName, symName, val
)
print varBindTableRow
我的问题是为什么snmpwalk和pysnmp结果不同,我该怎么做才能使用pysnmp模块获得与snmpwalk相同的结果?
的被修改 :
我尝试了代码,但是在查询1.3.6.1.2.1.4.22.1 我收到以下错误
NoSuchObjectError: NoSuchObjectError({'str': 'No MIB info for (1, 3, 6, 1, 4, 1, 2021, 4, 1, 0) (closest parent (1, 3, 6, 1, 4, 1))'})
我已将IP-MIB模块加载为:
mibBuilder = builder.MibBuilder()
mibPath = mibBuilder.getMibSources()+(builder.DirMibSource(path_to_mib_dir),)
mibBuilder.setMibSources(*mibPath)
mibBuilder.loadModules('IP-MIB')
mibView = view.MibViewController(mibBuilder)
我感到困惑的是如何在
中使用 mibView(symName,modName),indices=cmdgen.mibvar.oidToMibName(cmdGen.mibViewController, oid)
val=cmdgen.mibvar.cloneFromMibValue(cmdGen.mibViewController,modName, symName, val)
是否应将 cmdGen.mibViewController 替换为 mibView ?
但它适用于OID 1.3.6.1.2.1.1.3: 我得到了预期的结果:
SNMPv2-MIB::sysUpTime.0 = 27
答案 0 :(得分:0)
很抱歉,但结果是一样的!
如果您的问题大约是16000而不是16000 KB,则必须知道SNMP不会返回该单元。 SNMP V2 MIB只允许一个地方提供有关它的信息,因此SNMPWALK(作为客户端)正在使用它,而不是pysnmp。
答案 1 :(得分:0)
尝试打印:
print '%s::%s.%s = %s' % (
modName, symName,
'.'.join(map(lambda v: v.prettyPrint(), indices),
val.prettyPrint()
)
而不是
print varBindTableRow
还要确保加载适当的MIB。