Comment obtenir la valeur mac et vlan de la table fdb utilise python?
Dans bash snmpwalk fonctionne très bien:
snmpwalk -v2c -c pub 192.168.0.100 1.3.6.1.2.1.17.7.1.2.2.1.2
pysnmp:
import os, sys
import socket
import random
from struct import pack, unpack
from datetime import datetime as dt
from pysnmp.entity.rfc3413.oneliner import cmdgen
from pysnmp.proto.rfc1902 import Integer, IpAddress, OctetString
ip='192.168.0.100'
community='pub'
value=(1,3,6,1,2,1,17,7,1,2,2,1,2)
generator = cmdgen.CommandGenerator()
comm_data = cmdgen.CommunityData('server', community, 1) # 1 means version SNMP v2c
transport = cmdgen.UdpTransportTarget((ip, 161))
real_fun = getattr(generator, 'getCmd')
res = (errorIndication, errorStatus, errorIndex, varBinds)\
= real_fun(comm_data, transport, value)
if not errorIndication is None or errorStatus is True:
print "Error: %s %s %s %s" % res
else:
print "%s" % varBinds
sortie: [(ObjectName (1.3.6.1.2.1.17.7.1.2.2.1.2), NoSuchInstance (''))]
import netsnmp
def getmac():
oid = netsnmp.VarList(netsnmp.Varbind('.1.3.6.1.2.1.17.7.1.2.2.1.2'))
res = netsnmp.snmpgetbulk(oid, Version = 2, DestHost='192.168.0.100',
Community='pub')
return res
print getmac()
sortie: ('27', '27', '25', '27', '27', '27', '24', '27', '25', '18', '4', '27' , '25', '27', '27', '25', '27', '27', '27', '27', '27', '27', '27', '27', ' 27 ',' 27 ',' 27 ',' 27 ',' 27 ',' 27 ',' 27 ',' 27 ',' 23 ',' 25 ',' 27 ',' 27 ',' 27 ' , '25', '27', '25', '27', '27', '25', '27', '27', '27', '27', '27', '27', ' 27 ',' 27 ',' 27 ',' 25 ',' 27 ',' 27 ',' 27 ',' 27 ',' 27 ',' 27 ',' 27 ',' 27 ',' 27 ' , '27', '27', '27', '25', '25', '25', '7', '27', '27', '9', '25', '27', ' 20 ',' 19 ',' 27 ',' 27 ',' 27 ',' 27 ',' 27 ',' 27 ',' 27 ',' 27 ',' 27 ',' 27 ',' 27 ' , '27', '27', '27', '11', '25', '27', '27', '27', '27', '27', '27', '27', ' 27 ',' 27 ',' 27 ',' 27 ',' 27 ',' 27 ',' 27 ',' 25 ',' 27 ',' 27 ',' 27 ',' 27 ',' 27 ' , '27', '27', '27', '27', '2', '27', '5', '27', '0', '27', '27', '27', ' 27 ',' 27 ')
Le premier script (pysnmp) renvoie NoSuchInstance. Le deuxième script (netsnmp) renvoie la liste des ports mais sans mac et vlan. Qu'est-ce qui ne va pas?
Dans l'exemple pysnmp, vous faites un SNMPGET (snmpget), pas un GETNEXT (snmpwalk). Si vous changez,
real_fun = getattr(generator, 'getCmd')
à
real_fun = getattr(generator, 'nextCmd')
vous commencerez à voir des résultats utiles.
Quant à l'écart que vous avez vu dans les résultats entre snmpwalk
et le résultat des liaisons python net-snmp
: snmpwalk
et snmpbulkget
Si vous faites un snmpbulkget
à partir de la ligne de commande avec les mêmes options que le snmpwalk
, vous recevrez les mêmes résultats que votre python net-snmp
Exemple.
Si vous mettez à jour la ligne suivante dans votre exemple python net-snmp
,
res = netsnmp.snmpgetbulk(oid, Version=2, DestHost='192.168.0.100',
Community='pub')
à
res = netsnmp.snmpwalk(oid, Version=2, DestHost='192.168.0.100',
Community='pub')
alors vous devriez maintenant obtenir la même liste de résultats de l'exemple python net-snmp
que vous voyez lorsque vous faites un snmpwalk
sur la ligne de commande.