• SNMP4J与ObjectSNMP对比分析


    SNMP4J是一个用Java来实现SNMP(简单网络管理协议)协议的开源项目.它支持以命令行的形式进行管理与响应。Object SNMP是一个面向对象的SNMP开发组件,与关系数据库流行的O-R Mapping技术类似,实现了Object到SNMP MIB的操作映射(简称O-M Mapping)。使用SNMP4J与ObjectSNMP开发类似于使用原生JDBC开发与Hibernate框架。

    SNMP4J介绍

      SNMP4J是一个用Java来实现SNMP(简单网络管理协议)协议的开源项目.它支持以命令行的形式进行管理与响应。SNMP4J是纯面向对象设计与SNMP++(用C++实现SNMPv1/v2c/v3)相类似。

    1. 支持MD5和SHA验证,DES,3DES,AES128、AES192和AES256加密的SNMPv3。
    2. 支持MPv1,MPv2C和MPv3,带执行的可阻塞的信息处理模块。
    3. 全部PDU格式。
    4. 可阻塞的传输拓扑。支持UPD、TCP、TLS 。
    5. 可阻塞的超时模块。
    6. 同步和异步请求。
    7. 命令发生器以及命令应答器的支持。
    8. 基于Apache license的开源免费。
    9. JAVA 1.4.1或更高版本(2.0或更高版本需要jdk1.6及以上的支持)。
    10. 基于LOG4J记录日志。
    11. 使用GETBULK实现Row-based的有效的异步表格获取。
    12. 支持多线程。

    ObjectSNMP介绍

      Object SNMP(Object Simple Network Management Protocol)是一个面向对象的SNMP开发组件,与关系数据库流行的O-R Mapping技术类似,实现了Object到SNMP MIB的操作映射(简称O-M Mapping),系统提供了Java/SNMP网关、RMI/SNMP网关 、Web Service/SNMP网关服务。开发者无需理解SNMP协议和MIB细节,只需要定义普通数据对象,然后将数据对象按添加、删除、修改、查询等模式提交给网关即可。Object SNMP网关会自动将数据对象按开发者的期望发送到SNMP设备,并返回用户需要的数据对象。Object SNMP提供诸如分布式代理SNMP网关、 网络拓扑发现、物理拓扑发现、网络自动搜索发现 、设备连接关系发现、设备类型发现、网络漫游搜索、以及定义好的可管理各种设备的MIB数据等高级功能。

      ObjectSNMP提供四种网关API模型,满足绝大多数开发者的需求。所有网关的API保持一致,都提供了基于数据对象添加、删除、修改、查询等服务;并可以随意切换各种网关模式,保持API对用户不变。

    1.O-M Mapping映射框架

      参考数据库领域流行的O-RMapping技术,实现SNMP领域的Object-MIB映射框架,自动翻译MIB和OID语法、SNMP命令和网络操作,彻底告别Socket、PDU、UDP、SNMPGet等方式的编程模式,开发人员仅需定义一个与MIB数据相对应的普通数据对象。然后通过各种网关提交数据对象,即可完成对SNMP的复杂访问。

    2.Java/SNMP网关

      使用者的程序和ObjectSNMP在同一个Java进程内,使用者定义普通Java数据对象,然后通过Java API访问ObjectSNMP网关。

    3.Java RMI/SNMP网关

      使用者的程序和ObjectSNMP在不同的Java进程内,或在不同的机器上。使用者定义普通Java数据对象,然后通过RMI Java API访问ObjectSNMP网关。

    4.Web Service/SNMP网关

      使用者可以为PHP、C++、.NET、Java、Flex、JavaScrip等支持Web Service技术的其他程序,通过在Web环境中,访问ObjectSNMP网关。Web Servcie/SNMP网关支持任意兼容servlet的Web容器。

    5.Proxy/SNMP透明网关

      为私网穿透、分布式部署SNMP网关、SNMP网关负载均衡、主/从两级SNMP管理 等场景提供了透明的SNMP网关服务。Proxy网关可以采用Java、RMI、Web Service任意模式,并且完全对用户透明,就如同只有一个网关一样。

    6.一致的API服务

      所有的网关的API保持一致,都提供了基于数据对象添加、删除、修改、查询等服务;并可以随意切换各种网关模式,保持API对用户不变。

    7.SNMP Trap接收服务

      内置SNMP Trap接收服务器,可以接收公共和私有SNMP Trap消息。并自动将原始Trap PDU包解析成Java Trap消息对象。为了简化Trap通知模式的编程开发,ObjectSNMP将被动接收的Trap消息机制映射成为主动获取Java Trap消息对象的普通编程模式。

    8.网管集成

      ObjectSNMP依托底层O-M框架和网关技术,针对诸如故障管理、性能监控管理、故障监控、配置管理、业务管理、网络安全管理等SNMP网管功能,提供了最为便捷的支持。

    9.支持私有MIB文件

      产品可以加载各种厂商的私有MIB文件,加载私有MIB文件后,自动解析MIB文件的语法。

    10.网络自动发现功能

      采用全新的技术:即支持单一Cisco、华为网络,也支持各种厂商设备混合网络。支持模糊连接定位,在数据不全或设备缺失的情况下,尽可能发现连接关系。可在任意的网络环境中工作,不需要用户对网络做任何假设。

    11.SNMP数据采集服务

      ObjectSNMP提供如下常用数据采集服务,使用者可直接使用:系统类MIB描述、IP网络类MIB描述、交换机MIB描述、硬件设施类MIB描述、软件类MIB描述、Java类MIB描述。

    12.自动Java代码生成技术

      提供了Java数据对象代码的自动生成技术,进一步简化SNMP开发工作。

    13.SNMP MIB数据浏览器

      可单独使用,也可集成在程序中使用SNMP数据浏览器,便于开发和调试。

    14.优秀的性能表现

    • 单线程1万个SNMP对象(7万个SNMP OID数据)获取总时间<=5秒
    • 多线程并发1万个SNMP对象获取总时间<=2秒
    • 连续30天多线程并发获取SNMP数据,内存波动正负0.3M
    • 1千万次SNMP对象获取操作,在多线程并发环境下,正确率100%

    SNMP4J与ObjectSNMP实例对比

    (一)获取snmp简单基本数据

    1.Snmp4j步骤:

    1)创建Target(Target代表远程设备或者远程实体),包括设备地址,SNMP端口,snmp团体字,SNMP版本,超时时间,重试次数等信息。

    2)创建PDU(代表管理端同Target通信的数据),在PDU中增加要获取的OID值,设置访问的方式。

    3)创建SNMP(代表着管理者,作用是通信的具体实行者)

    4)向Agent发送PDU,并接收Response响应 

    5)解析Resoponse响应。

     1 // 设置 target  
     2    CommunityTarget target = new CommunityTarget();  
     3    target.setCommunity(new OctetString("public"));  
     4    Address targetAddress = GenericAddress.parse("udp:127.0.0.1/161");  
     5    target.setAddress(targetAddress);//设置目标设备地址、端口  
     6    target.setRetries(2); // 通信不成功时的重试次数  
     7    target.setTimeout(1500);// 超时时间  
     8    target.setVersion(SnmpConstants.version1);//设置版本  
     9   
    10    // 创建 PDU  
    11    PDU pdu = new PDU();  
    12    pdu.add(new VariableBinding(new OID(new int[] { 1, 3, 6, 1, 2, 1, 1, 5, 0 })));  
    13    pdu.setType(PDU.GET);// MIB的访问方式  
    14      
    15    TransportMapping transport = new DefaultUdpTransportMapping();  
    16    Snmp snmp = new Snmp(transport);  
    17    ResponseEvent respEvnt = snmp.send(pdu, target);// MIB的访问方式  
    18   
    19    // 解析Response  
    20    if (respEvnt != null && respEvnt.getResponse() != null) {  
    21         Vector<VariableBinding> recVBs = respEvnt.getResponse().getVariableBindings();  
    22           for (int i = 0; i < recVBs.size(); i++) {  
    23                  VariableBinding recVB = recVBs.elementAt(i);  
    24                  System.out.println(recVB.getOid() + " : " + recVB.getVariable());  
    25           }  
    26    }  

    2.使用ObjectSNMP获取数据:

    1)创建SNMPTarget,包括设备地址,SNMP端口,snmp团体字,SNMP版本,超时时间,重试次数等信息。

    2)获取SNMPAPI,根据OID获取SNMP数据。

    //封装Target  
     SNMPTarget target = new SNMPTarget();  
     target.nodeIP="127.0.0.1";  
     target.port=161;  
     target.readCommunity="public";  
     target.snmpVersion = target.VERSION2C;  
       
     //获取信息  
     String result = SNMPFactory.getSNMPAPI().getOIDValue("1, 3, 6, 1, 2, 1, 1, 5, 0",target);  

     结论:对于SNMP简单数据的获取,即根据单个OID获取相应信息,ObjectSNMP更为简单方便。

    (二)操作snmp表、组数据

      所有的SNMP MIB可以分为两大类,一类称之为组如下图的system组,有查询、修改操作,

     

     

     

    与之相映射的JAVA对象分别是:

    public class MibSystem implements com.zhtelecom.common.snmp.OMMappingInfo  
    {  
        private String sysDescr;  
        private String sysObjectID;  
        private long sysUpTime;  
        private String sysContact;  
        private String sysName;  
        private String sysLocation;  
        private int sysServices;  
            get/set ……..  
        public String getMappingOID()  //告诉要映射system组的OID  
        {  
            return "1.3.6.1.2.1.1";  //system组的OID  
        }  
    }  
      
    Public class MibOspfStubAreaEntry implements com.zhtelecom.common.snmp.OMMappingInfo  
    {  
        private String ospfStubAreaId;  
        private int ospfStubTOS;  
        private int ospfStubMetric;  
        private int ospfStubStatus;  
        private int ospfStubMetricType;  
      
        public String getMappingOID()  
        {  
            return "1.3.6.1.2.1.14.3.1"; // ospfStubAreaEntry的OID  
        }  
    }  
    //获取MibOspfStubAreaEntry表中所有数据  
    List list= snmpapi. getAllTableData(MibOspfStubAreaEntry.class, target);  
    //在MibOspfStubAreaEntry 表中添加一行数据  
    MibOspfStubAreaEntry ospf = new MibOspfStubAreaEntry();  
    ospf.setOspfStubTOS(3);  
    ospf.setOspfStubStatus(SNMPAPI.RowStatusEntryAdd); //设置snmp rowstatus的值为添加。  
    ospf.setOspfStubMetricType(2);  
    snmpapi.addTableRow(ospf, target);  
    //表中删除一行数据  
    MibOspfStubAreaEntry ospf = new MibOspfStubAreaEntry();//设置snmp rowstatus的值为删除语义  
    ospf.setOspfStubStatus(SNMPAPI.RowStatusEntryDel);  
    snmpapi.delTableRow(ospf, target);  
      
    //修改MibOspfStubAreaEntry mib表中一行数据  
    MibOspfStubAreaEntry ospf = new MibOspfStubAreaEntry();  
    ospf.setOspfStubAreaId("192.168.9.0");  
    ospf.setOspfStubTOS(3);  
    ospf.setOspfStubStatus(SNMPAPI.RowStatusEntryActive); //设置snmp rowstatus的值为激活语义。  
    ospf.setOspfStubMetric(3);  
    ospf.setOspfStubMetricType(3);  
    snmpapi.update(ospf, target);  

    可以看出通过ObjectSNMP操作数据极其方便简单,相比于SNMP4J从易用性和功能性来说得到了很大的提高,而且通过对象的方式对SNMP进行操作,更符合用户的使用习惯,且屏蔽掉了SNMP4J中的PDU、ScopedPDU类、TransportMapping等,学习成本降低了很多。

    (三)基于ObjectSNMP与SNMP开发对比

    项目

    使用ObjectSNMP开发

    SNMP4J

    软件架构

    底层实现对SNMP协议的封装,上层提供基于对象的网关服务和各种高级服务。

    实现对SNMP协议的原始封装

    开发技能要求

    仅需了解SNMP概念即可开发,并提供对象代码自动生成工具

    需要对Socket、SNMP数据类型等有开发级的掌握。

    开发效率

    对象级的上层抽象操作。代码量仅有传统模式的10%

    大量的SNMP协议层操作代码

    开发时间

    在SNMP模块开发和设备联调上花费的时间仅有传统模式的20%

    需要专人负责SNMP模块的开发和后期维护

    软件性能

    已通过基准性能验证,新定义的数据对象直接在网关通道上传递

    需要大量的调优、测试、验证来保证

    软件模式

    有统一的对象模式和网关模式,与整体软件的对象风格保持一致

    无,需要开发人员重新建立

    网关功能

    同时支持Java、RMI、Web Service、Proxy等多种网关

    高级服务

    全新技术的网络拓扑自动发现和网络资源发现

    预定义MIB对象

    提供多种内置MIB采集服务,如网络接口、流量、数据包、IP、CPU、磁盘、内存等

  • 相关阅读:
    CCF CSP 201509-1 数列分段
    CCF CSP 201503-1 图像旋转 (降维)
    CCF CSP 201412-1 门禁系统
    CCF CSP 201409-1 相邻数对
    CCF CSP 201403-1 相反数
    CCF CSP 201312-1 出现次数最多的数
    Win10环境下 HTTP 错误 500.19
    牛客网 整数拆分 (动态规划)
    牛客网 放苹果
    LeetCode9 回文数
  • 原文地址:https://www.cnblogs.com/bryantzx/p/10672626.html
Copyright © 2020-2023  润新知