我正在使用此SNMP4J代码执行一些SNMP漫游。但是,当我在1.3.6.1.2.1.31.1.1.1.1(即ifName)上运行它时,它获得了由1.3.6.1.2.1.31.1.1.1.1.x表示的所有接口,但随后它还获得了1.3.6.1.2.1.31.1.1.1.2,它们是ifInMulticastPkts,有时是1.3.6.1.2.1.31.1.1.1.3,它们是ifInBroadcastPkts。我只对ifName感兴趣。
如何防止GETBULK在遍历MIB之前递增最后一位数字?
public ArrayList<String> walk(String oid) throws IOException, InterruptedException {
Snmp snmp = new Snmp(new DefaultUdpTransportMapping());
snmp.listen();
Address targetAddress = GenericAddress.parse(address);
CommunityTarget target = new CommunityTarget();
target.setCommunity(new OctetString(community));
target.setVersion(SnmpConstants.version2c);
target.setAddress(targetAddress);
target.setTimeout(3000); //3s
target.setRetries(1);
PDU pdu = new PDU();
pdu.setType(PDU.GETBULK);
pdu.setMaxRepetitions(200);
pdu.setNonRepeaters(0);
pdu.add(new VariableBinding(new OID(oid)));
ResponseEvent responseEvent = snmp.send(pdu, target);
PDU response = responseEvent.getResponse();
ArrayList<String> responsePieces = new ArrayList<String>();
if (response == null) {
System.out.println("TimeOut...");
}
else
{
if (response.getErrorStatus() == PDU.noError)
{
Vector<? extends VariableBinding> vbs = response.getVariableBindings();
for (VariableBinding vb : vbs) {
responsePieces.add(vb.toString());
}
}
else
{
System.out.println("Error:" + response.getErrorStatusText());
}
}
return responsePieces;
}
答案 0 :(得分:4)
您应该使用the getTable
method of the TableUtils
class来获取所需的列。这样,您就不必担心协议在走路时的行为方式的细节。
那就是说,如果你想自己做...你发现的是GetBulk的正常行为。代理仅负责返回指定的行数(200),如果有的话。如果您想要更多行,响应还将指示您应该请求的OID。
只有您作为经理才能告诉您何时获得所需的所有数据,并停止发送新的GetBulk请求。您应该简单地丢弃最后一个响应中的不需要的数据。在您的情况下,检测OID是否不再是您请求的列的子项。
您可以在RFC 1905中详细了解SNMP行走和GetBulk如何工作,尤其是第4.2.3和4.2.3.1节。
但是,请使用API提供的方法,它会为您节省一些白发,并保证是正确的。