如何让SNMP4J GETBULK在OID之前增加最右边的数字?

时间:2015-02-05 21:27:29

标签: java snmp snmp4j

我正在使用此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;
}

1 个答案:

答案 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​​提供的方法,它会为您节省一些白发,并保证是正确的。