0
這裏是我的snmpbulkwalk實現(把它從例子):超時而與pysnmp snmpbulkwalking
def bulk_walk(self, oid, context, conv):
walkdone = False
data = list()
if context:
community = "%[email protected]%s" % (self.community, context)
else:
community = self.community
for errorIndication, \
errorStatus, errorIndex, \
varBinds in bulkCmd(SnmpEngine(),
CommunityData(community),
UdpTransportTarget((self.ip, self.port)),
ContextData(), 0, 10,
ObjectType(ObjectIdentity(oid)), lookupMib=False):
if errorIndication:
raise(SNMPError(errorIndication))
elif errorStatus:
raise(SNMPError('%s at %s' % (
errorStatus.prettyPrint(),
errorIndex and varBinds[int(errorIndex)-1][0] or '?'
))
)
else:
for varBind in varBinds:
print(varBind[0].prettyPrint(), conv(varBind[1]))
if not varBind[0].prettyPrint().startswith(oid+"."):
walkdone = True
break
data.append((varBind[0].prettyPrint(), conv(varBind[1])))
if walkdone:
break
return(data)
我想snmpwalk的,不存在的OID,當我試圖用snmpbulkwalk我正在這樣做:
$ snmpwalk的-v2c -c公共@ 1 10.253.35.61 1.3.6.1.2.1.17.4.3.1.1
SNMPv2-SMI::mib-2.17.4.3.1.1 = No Such Instance currently exists at this OID
如果我們看一下tcpdump的,我們可以看到這一點:
11:26:00.460905 IP host.52491 > 10.253.35.61.snmp: [email protected] GetBulk(30) N=0 M=10 17.4.3.1.1
11:26:01.462162 IP host.52491 > 10.253.35.61.snmp: [email protected] GetBulk(30) N=0 M=10 17.4.3.1.1
11:26:01.658323 IP 10.253.35.61.snmp > host.52491: [email protected] GetResponse(215) 17.4.4.1.1.1414=1414 17.4.4.1.1.4103=4103 17.4.4.1.1.4104=4104 17.4.4.1.1.4115=4115 17.4.4.1.1.4136=4136 17.4.4.1.1.4137=4137 17.4.4.1.2.1414=1500 17.4.4.1.2.4103=1500 17.4.4.1.2.4104=1500 17.4.4.1.2.4115=1500
11:26:01.658561 IP host.52491 > 10.253.35.61.snmp: [email protected] GetRequest(30) 17.4.3.1.1
11:26:01.659643 IP 10.253.35.61.snmp > host.52491: [email protected] GetResponse(215) 17.4.4.1.1.1414=1414 17.4.4.1.1.4103=4103 17.4.4.1.1.4104=4104 17.4.4.1.1.4115=4115 17.4.4.1.1.4136=4136 17.4.4.1.1.4137=4137 17.4.4.1.2.1414=1500 17.4.4.1.2.4103=1500 17.4.4.1.2.4104=1500 17.4.4.1.2.4115=1500
11:26:01.660698 IP 10.253.35.61.snmp > host.52491: [email protected] GetResponse(30) 17.4.3.1.1=[noSuchInstance]
這是確定的,我可以看到錯誤並解決它,但是當我從pysnmp查詢它 - 我得到錯誤「之前超時未收到SNMP響應」,這裏是tcpdump的:
11:26:58.497144 IP host.54615 > 10.253.35.61.snmp: [email protected] GetBulk(29) N=0 M=25 17.4.3.1.1
11:26:59.499136 IP host.54615 > 10.253.35.61.snmp: [email protected] GetBulk(29) N=0 M=25 17.4.3.1.1
11:27:00.480834 IP 10.253.35.61.snmp > host.54615: [email protected] GetResponse(542) 17.4.4.1.1.1414=1414 17.4.4.1.1.4103=4103 17.4.4.1.1.4104=4104 17.4.4.1.1.4115=4115 17.4.4.1.1.4136=4136 17.4.4.1.1.4137=4137 17.4.4.1.2.1414=1500 17.4.4.1.2.4103=1500 17.4.4.1.2.4104=1500 17.4.4.1.2.4115=1500 17.4.4.1.2.4136=1500 17.4.4.1.2.4137=1500 17.4.4.1.3.1414=14191348 17.4.4.1.3.4103=371017501 17.4.4.1.3.4104=43993868 17.4.4.1.3.4115=379731251 17.4.4.1.3.4136=2614818874 17.4.4.1.3.4137=3830362616 17.4.4.1.4.1414=390518443 17.4.4.1.4.4103=547088805 17.4.4.1.4.4104=270695068 17.4.4.1.4.4115=2723143051 17.4.4.1.4.4136=2811735791 17.4.4.1.4.4137=102796762 17.4.4.1.5.1414=0
11:27:00.503200 IP host.54615 > 10.253.35.61.snmp: [email protected] GetBulk(29) N=0 M=25 17.4.3.1.1
11:27:01.505277 IP host.54615 > 10.253.35.61.snmp: [email protected] GetBulk(29) N=0 M=25 17.4.3.1.1
11:27:02.469848 IP 10.253.35.61.snmp > host.54615: [email protected] GetResponse(542) 17.4.4.1.1.1414=1414 17.4.4.1.1.4103=4103 17.4.4.1.1.4104=4104 17.4.4.1.1.4115=4115 17.4.4.1.1.4136=4136 17.4.4.1.1.4137=4137 17.4.4.1.2.1414=1500 17.4.4.1.2.4103=1500 17.4.4.1.2.4104=1500 17.4.4.1.2.4115=1500 17.4.4.1.2.4136=1500 17.4.4.1.2.4137=1500 17.4.4.1.3.1414=14191348 17.4.4.1.3.4103=371017846 17.4.4.1.3.4104=43994108 17.4.4.1.3.4115=380963114 17.4.4.1.3.4136=2616771624 17.4.4.1.3.4137=3830710704 17.4.4.1.4.1414=390519877 17.4.4.1.4.4103=547090599 17.4.4.1.4.4104=270696594 17.4.4.1.4.4115=2724485940 17.4.4.1.4.4136=2813399966 17.4.4.1.4.4137=102954755 17.4.4.1.5.1414=0
11:27:02.987802 IP host.54615 > 10.253.35.61.snmp: [email protected] GetBulk(29) N=0 M=25 17.4.3.1.1
11:27:03.989765 IP host.54615 > 10.253.35.61.snmp: [email protected] GetBulk(29) N=0 M=25 17.4.3.1.1
,這是不好的,因爲可能會有不同的情況,可能會導致超時(主機下降,錯誤的社區字符串等),我怎樣才能模仿snmpbulkwalk行爲與pysnmp,可能沒有去低級別的API。
謝謝。
不是這樣,snmpbulkwalk在第一次超時後從GetBulk切換到GetResponse。 pysnmp繼續GetBulk,直到超時。 –
GET和GETBULK是不同的命令,SNMP不要求它們一起使用。如果你想模擬snmpbulkwalk,你可以讓你的Python腳本和bulkCmd()一起調用getCmd()。爲了解決您最初的擔憂:pysnmp不會將timeout與no-such-oid錯誤條件混合在一起。圖書館報告發生的情況,不會掩蓋或取代任何錯誤。 –