2011-12-22 13 views
10

Come ottenere il valore mac e vlan dalla tabella fdb utilizza python?
In bash lavoro snmpwalk bene: Come ottenere dati da SNMP con Python?

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 

uscita: [(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() 

output: ('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 e 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', '2 7 ', ' 27 ',' 27 ',' 27 ',' 27 ',' 27 ',' 2 ',' 27 ',' 5 ',' 27 ',' 0 ',' 27 ', '27 ', '27', '27', '27')

sceneggiatura Firs (pysnmp) restituiscono noSuchInstance. Secondo script (netsnmp) restituisce la lista delle porte ma senza mac e vlan. Cosa c'è di sbagliato?

risposta

8

Nell'esempio pysnmp si sta eseguendo un SNMPGET (snmpget), non un GETNEXT (snmpwalk). Se si cambia,

real_fun = getattr(generator, 'getCmd') 

a

real_fun = getattr(generator, 'nextCmd') 

si inizierà a vedere i risultati utili.

Per quanto riguarda la discrepanza si è visto nei risultati tra snmpwalk e le associazioni di pitone net-snmp Risultato: snmpwalk e snmpbulkget si comportano in modo diverso. Se esegui un snmpbulkget dalla riga di comando con le stesse opzioni dello snmpwalk, riceverai gli stessi risultati del tuo esempio python net-snmp.

Se si aggiorna la seguente riga nel vostro pitone net-snmp esempio,

res = netsnmp.snmpgetbulk(oid, Version=2, DestHost='192.168.0.100', 
          Community='pub') 

a

res = netsnmp.snmpwalk(oid, Version=2, DestHost='192.168.0.100', 
         Community='pub') 

allora si dovrebbe ora ottenere lo stesso elenco di risultati dal esempio python net-snmp come si vede quando fai un snmpwalk sulla riga di comando.