我正在使用此SNMP4J代码进行一些SNMP遍历。但是,当我在运行1.3.6.1.2.1.31.1.1.1.1时(即ifName)运行时,它将获得由1.3.6.1.2.1.31.11.1.1.1.1.x表示的所有接口。还可以获取1.3.6.1.2.1.31.1.1.1.2,它们是ifInMulticastPkt,然后有时是1.3.6.1.2.1.31.11.1.1.1.3,它们是ifInBroadcastPkt。我只对ifName感兴趣。

在遍历MIB之前如何防止GETBULK递增最后一位数字?

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;
}

最佳答案

您可能应该使用the getTable method of the TableUtils class来获取所需的列。这样,您就不必担心协议在走路时的行为细节。

就是说,如果您想自己做……发现的就是GetBulk的正常行为。如果有行,则代理仅负责返回指定的行数(200)。如果需要更多行,响应还将指示您应请求的OID。

只有作为管理员的您才能告诉您何时拥有所需的所有数据,并停止发送新的GetBulk请求。您应该只在上次响应中丢弃不需要的数据。对于您的情况,请检测OID是否不再是您请求的列的子代。

您可以在RFC 1905中阅读有关SNMP walk和GetBulk如何工作的更多信息,尤其是在4.2.3和4.2.3.1节中。

但是请务必使用API​​提供的方法,它将为您节省一些白发,并且保证是正确的。

10-06 16:05