snmp 协议开发之SNMP4J-SNMPv1/v2

转载 2015年07月09日 14:13:56
使用SNMP4J可以很方便的实现一个SNMP NMS的功能。
对于SNMPv1/SNMPv2,简单的说,只需要以下几个步骤
1) 创建Snmp对象snmp

2) 创建CommunityTarget对象target,并指定community, version, address, timeout, retry等参数。

3) 创建PDU对象pdu,并指定操作类型(GET/GETNEXT/GETBULK/SET), 添加VariableBinding(也就是待操作的OID),
    如果是GETBULK操作,还可以指定MaxRepetitions和NonRepeaters。
 注意一定要指定MaxRepetitions,默认值是0,那样不会返回任何结果。

4) 调用snmp.send(pdu, target)方法,发送请求请返回结果。

此外,SNMP4J提供了TableUtils类,可以很轻松的实现一个SNMP Walk的功能,比如一次返回一个表格下面的所有MIB值。
TableUtils类还支持指定ower bound index 和 upper bound index, 得到更小范围的结果以提高性能。这一点对于从一个很多行的表中取一部分行的数据来说很重要。

Snmp还支持异步的send方法。

下面的代码实例实现了GET, GETNEXT, GETBULK, Walk, SET操作,
以及一个利用异步send方法实现的agent discovery: 对一个广播地址发送请求,等待agent返回的应答。

如果需要对一个范围内的IP进行扫描,可以稍加改进,反复调用异步send多次发送给不同IP。

package com.snmp.demo;

import org.snmp4j.CommunityTarget;
import org.snmp4j.PDU;
import org.snmp4j.Snmp;
import org.snmp4j.event.ResponseEvent;
import org.snmp4j.event.ResponseListener;
import org.snmp4j.mp.SnmpConstants;
import org.snmp4j.smi.OID;
import org.snmp4j.smi.OctetString;
import org.snmp4j.smi.UdpAddress;
import org.snmp4j.smi.VariableBinding;
import org.snmp4j.transport.DefaultUdpTransportMapping;
import org.snmp4j.util.DefaultPDUFactory;
import org.snmp4j.util.TableEvent;
import org.snmp4j.util.TableUtils;

import java.io.IOException;
import java.util.List;
import java.util.Vector;

/**
 * Created by vixuan-008 on 2015/7/9.
 */
public class SNMPv1 {
    public static void main(String[] args) throws Exception {
        Snmp snmp = new Snmp(new DefaultUdpTransportMapping());
        snmp.listen();

        CommunityTarget target = new CommunityTarget();
        target.setCommunity(new OctetString("public"));
        target.setVersion(SnmpConstants.version2c);
        target.setAddress(new UdpAddress("127.0.0.1/161"));
        target.setTimeout(3000);    //3s
        target.setRetries(1);

        sendRequest(snmp, createGetPdu(), target);
        sendRequest(snmp, createGetNextPdu(), target);
        sendRequest(snmp, createGetBulkPdu(), target);
        snmpWalk(snmp, target);()

        target.setCommunity(new OctetString("public"));
        sendRequest(snmp, createSetPdu(), target);

        CommunityTarget broadcastTarget = new CommunityTarget();
        broadcastTarget.setCommunity(new OctetString("public"));
        broadcastTarget.setVersion(SnmpConstants.version2c);
        broadcastTarget.setAddress(new UdpAddress("192.168.0.204/161"));
        broadcastTarget.setTimeout(5000);   //5s
        sendAsyncRequest(snmp, createGetNextPdu(), broadcastTarget);
        Thread.sleep(6000); //main thread wait 6s for the completion of asynchronous request
    }
    private static PDU createGetPdu() {
        PDU pdu = new PDU();
        pdu.setType(PDU.GET);
        pdu.add(new VariableBinding(new OID("1.3.6.1.2.1.1.3"))); //sysUpTime
        pdu.add(new VariableBinding(new OID("1.3.6.1.2.1.1.5.0"))); //sysName
        pdu.add(new VariableBinding(new OID("1.3.6.1.2.1.1.5")));   //expect an no_such_instance error
        return pdu;
    }

    private static PDU createGetNextPdu() {
        PDU pdu = new PDU();
        pdu.setType(PDU.GETNEXT);
        pdu.add(new VariableBinding(new OID("1.3.6.1.2.1.1.3")));   //sysUpTime
        pdu.add(new VariableBinding(new OID("1.3.6.1.2.1.1.5")));   //sysName

        return pdu;
    }

    private static PDU createGetBulkPdu() {
        PDU pdu = new PDU();
        pdu.setType(PDU.GETBULK);
        pdu.setMaxRepetitions(10);  //must set it, default is 0 .1.3.6.1.2.1.1.1.0
        pdu.setNonRepeaters(0);
        pdu.add(new VariableBinding(new OID("1.3.6.1.2.1.1")));     //system
        return pdu;
    }

    private static PDU createSetPdu() {
        PDU pdu = new PDU();
        pdu.setType(PDU.SET);
        pdu.add(new VariableBinding(new OID("1.3.6.1.2.1.1.5.0"), new OctetString("sysname"))); //sysName
        return pdu;
    }

    private static void sendRequest(Snmp snmp, PDU pdu, CommunityTarget target)
            throws IOException {
        ResponseEvent responseEvent = snmp.send(pdu, target);
        PDU response = responseEvent.getResponse();

        if (response == null) {
            System.out.println("TimeOut...");
        } else {
            if (response.getErrorStatus() == PDU.noError) {
                Vector<? extends VariableBinding> vbs = response.getVariableBindings();
                for (VariableBinding vb : vbs) {
                    System.out.println(vb + " ," + vb.getVariable().getSyntaxString());
                }
            } else {
                System.out.println("Error:" + response.getErrorStatusText());
            }
        }
    }

    private static void sendAsyncRequest(Snmp snmp, PDU pdu, CommunityTarget target)
            throws IOException {
        snmp.send(pdu, target, null, new ResponseListener(){

            @Override
            public void onResponse(ResponseEvent event) {
                PDU response = event.getResponse();
                System.out.println("Got response from " + event.getPeerAddress());
                if (response == null) {
                    System.out.println("TimeOut...");
                } else {
                    if (response.getErrorStatus() == PDU.noError) {
                        Vector<? extends VariableBinding> vbs = response.getVariableBindings();
                        for (VariableBinding vb : vbs) {
                            System.out.println(vb + " ," + vb.getVariable().getSyntaxString());
                        }
                    } else {
                        System.out.println("Error:" + response.getErrorStatusText());
                    }
                }
            }});
    }

    private static void snmpWalk(Snmp snmp, CommunityTarget target) {
        TableUtils utils = new TableUtils(snmp, new DefaultPDUFactory(PDU.GETNEXT));//GETNEXT or GETBULK
        utils.setMaxNumRowsPerPDU(5);   //only for GETBULK, set max-repetitions, default is 10
        OID[] columnOids = new OID[] {
                new OID("1.3.6.1.2.1.1.9.1.2"), //sysORID
                new OID("1.3.6.1.2.1.1.9.1.3"), //sysORDescr
                new OID("1.3.6.1.2.1.1.9.1.5")  //wrong OID, expect an null in in VariableBinding array
        };
        // If not null, all returned rows have an index in a range (lowerBoundIndex, upperBoundIndex]
        List<TableEvent> l = utils.getTable(target, columnOids, new OID("3"), new OID("10"));
        for (TableEvent e : l) {
            System.out.println(e);
        }
    }
}


举报

相关文章推荐

使用Java进行SNMP编程-SNMP4J-SNMPv1/v2-代码实例

使用SNMP4J可以很方便的实现一个SNMP NMS的功能。 对于SNMPv1/SNMPv2,简单的说,只需要以下几个步骤 1) 创建Snmp对象snmp 2) 创建CommunityTarget对...
  • fw0124
  • fw0124
  • 2013-01-31 15:06
  • 20819

SNMPv1原理

主要内容: 1、概述 在网络管理站与网络管理代理之间或者网络管理站与网络管理站之间要交换网络管理信息,这些网络管理信息的表示方法、组织方式和内容定义需要进行标准化,这些问题属于表示层的问题 ...

精选:深入理解 Docker 内部原理及网络配置

网络绝对是任何系统的核心,对于容器而言也是如此。Docker 作为目前最火的轻量级容器技术,有很多令人称道的功能,如 Docker 的镜像管理。然而,Docker的网络一直以来都比较薄弱,所以我们有必要深入了解Docker的网络知识,以满足更高的网络需求。

snmp4j 实现 trap监听

snmp4j 实现 trap监听代码可实现基本的trap监听,仅供参考。

SNMP 使用SNMP4J V2进行TRAP

SNMP trap(SNMP 陷阱):某种入口,到达该入口会使SNMP被管设备主动通知SNMP管理器,而不是等待SNMP管理器的再次轮询! 在网管系统中,被管理设备中的代理可以在任何时候向网络管理工作...

SNMP 使用SNMP4J V2进行TRAP

SNMP trap(SNMP 陷阱):某种入口,到达该入口会使SNMP被管设备主动通知SNMP管理器,而不是等待SNMP管理器的再次轮询! 在网管系统中,被管理设备中的代理可以在任何时候向网络管理工作...

SNMP学习之Snmp4j

文章转自:http://blog.csdn.net/clearwater21cn/article/details/1667614 相关链接: Snmp学习笔记 使用snmp4j实现Snmp功...

SNMP入门--SNMP4J实现SNMP

初学SNMP。 源于网上的代码,自己再修改了些。 一、SNMP-Get-Set package snmp.setget; import java.io.IOException; import j...

利用脚本扩展snmp收集信息

snmp开发小记 最近公司需要开发一个适用于自己集群的监控软件,在调研了ganlia等监控工具后,决定采用snmp+rrd+MySQL的方式来完成节点数据的采集和存储工作。本人主要负责snmp,下文会...

用snmp4j开发网管应用(一) - SNMP

要开发网管应用,SNMP是必学的协议,这里首先对SNMP进行一下简单的介绍和想要开发SNMP协议的内容所需要用到的工具。   SNMP SNMP 协议分为了多个版本,V1太简单,V2加入了一些验...
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)