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

要开发网管应用,SNMP是必学的协议,这里首先对SNMP进行一下简单的介绍和想要开发SNMP协议的内容所需要用到的工具。

SNMP

SNMP 协议分为了多个版本,V1太简单,V2加入了一些验证,V3最严谨,下面都是以V2进行说明

概念:

ASN.1 高级数据描述语言,用于定义数据类型,语法规则等。

BER ASN.1的基本编码规则,发送消息之前经过其编码,接收后先解码

SMI 管理信息结构,ASN.1的子集加上一部分宏等内容。SNMP用它来描述MIB和PDU

MIB 管理信息库,一般是一个树形结构,使用SMI描述,用来定义一个或者多个网元

OID 网络节点的唯一ID,用在MIB中,是一个国际机构统一分配的,比如1.3.6.1.4.1代表enterprises企业网

PDU SNMP协议数据单元,是一个数据包的格式。每一种SNMP方法对应一种PDU,使用SMI描述,BER编码,传输层(UDP)协议进行传输

SNMP跟网管有关的开发可能会涉及如下的内容:

1. 获取网元信息

  •     网元已经存在,其提供MIB文件,其中定义了该网元节点的结构以及想获取该结构内容所需要用到的OID
  •     使用代码或者其他的方式构建PDU,比如用snmp4j构建一个get请求类型的PDU(这个PDU是SMI描述的,BER编码的,包含了要操作的OID)到网元,得到返回结果。
  •     根据返回结果进行操作(可以通过getNext达到遍历的效果),或者是把单纯的数据信息持久化起来用于观察。

2. 设置网元参数

  •     发送set请求的PDU到网元达到设置网元某个参数的作用

3. 开发trap服务器接收trap消息

  •     开发trap接收服务端,并在在网元端配置服务器端地址,网元因为某个时间出发一个trap发送到该服务端。
  •    服务端记录该trap消息,用于数据分析

4. 开发一个网元模拟器

  •     开发一个模拟器,自己作为网元被人管理,通常用于测试。因为网管系统对应的真是网元都是昂贵的硬件,不容易找到合适的测试环境。

为了进行网元开发,首先我们需要准备一下所用到的工具

MIB Browser

下载地址:http://ireasoning.com/download.shtml

可以下载

  iReasoning MIB Browser Free Personal Edition         

这个版本是个人版,没有时间限制,但是有导入的mib文件数量的限制,不过很适合开发使用。

我自己写了一个文件上传到附件中,这里对这个文件进行简单的说明。

文件主要内容:

    

CMS-MIB DEFINITIONS ::= BEGIN 

 // 文件描述开始

  

IMPORTS                                                      
   MODULE-IDENTITY, OBJECT-TYPE, Counter32, Gauge32, Integer32, enterprises,

  // 导入基本的库,特别注意enterprises.他的oid是1.3.6.1.4.1

convediaCorp   OBJECT IDENTIFIER ::= { enterprises 7569 } 

    // 定义了一个节点,表示他是enterprises+ 7569,所以他的Oid是1.3.6.1.4.1.7569

    

nodeInfo             OBJECT IDENTIFIER ::= { msMIBObjects 1 }

    // 按照上面的类推,这个节点的Oid为.1.3.6.1.4.1.7569.1.2.1.1

  

nodeLicensedPorts OBJECT-TYPE   
   SYNTAX      Integer32 (0.. 65535)
   MAX-ACCESS  read-only
   STATUS      current
   DESCRIPTION
      "Future: The maximum number of ports licensed for this MS."
   DEFVAL { 18000   }
   ::= { nodeInfo 1 } 

 // 表示从属于nodeInfo的一个节点。其Oid为.1.3.6.1.4.1.7569.1.2.1.1.1.0可以通过get OID这样的结构得到这个属性的值,后续会说具体的方式。

    这里说一下SMI定义一个OBJECT-TYPE的结构。

  • SYNTAX表示值的类型为Integer32,SMI本身定义了很少的基本类型和一个复合类型Sequences.
  • MAX-ACCESS 访问权限,这个在MibBrowers中read-only表示为一个叶子,write表示为一个笔尖
alarmTable  OBJECT IDENTIFIER ::= { msMIBObjects 23 }
alarmEventTable OBJECT-TYPE
   SYNTAX      SEQUENCE OF AlarmEventEntry
   MAX-ACCESS  not-accessible
   STATUS      current
   DESCRIPTION
      "A list of alarm status history entries."
   ::= { alarmTable 3 }

alarmEventEntry OBJECT-TYPE
   SYNTAX      AlarmEventEntry
   MAX-ACCESS  not-accessible
   STATUS      current
   DESCRIPTION
      "An entry in the Alarm Event Table."
   INDEX   { aleEventIndex }
   ::= { alarmEventTable 1 }

AlarmEventEntry ::=
   SEQUENCE {
      aleEventIndex        Unsigned32,
      aleSequenceID        Unsigned32,
      aleEventTime         DateAndTime,
      aleEventType         EventType,
      aleAlarmID           Unsigned32,
      aleAlarmText         DisplayString,
      aleAlarmSeverity     AlarmSeverity,
      aleInstanceID        Unsigned32,
      aleSlotNumber        Unsigned32
   }

aleEventIndex OBJECT-TYPE
   SYNTAX      Unsigned32 (1.. 2000 )
   MAX-ACCESS  not-accessible
   STATUS      current
   DESCRIPTION
      "This object is used as a key attribute to
      specify the row entry in this table."
   ::= { alarmEventEntry 1 }

aleSequenceID OBJECT-TYPE
   SYNTAX      Unsigned32
   MAX-ACCESS  read-only
   STATUS      current
   DESCRIPTION
      "Unique sequential event identification number."
   ::= { alarmEventEntry 2 }

     // 关键来了,这里定义了一个Table,SMI中使用SEQUENCE 来定义复杂的结构,该结构可以看做是一个表,然后可以通过get,getNext来遍历这张表中的内容。

alarm001 NOTIFICATION-TYPE
   OBJECTS { aleSequenceID, aleEventType, aleAlarmID, aleInstanceID,
             aleAlarmText, aleAlarmSeverity, aleEventTime, aleSlotNumber }
   STATUS  current
   DESCRIPTION
      "External alarm 1 has been triggered. Text and severity
      of this alarm are user-configurable. This alarm is
      deactivated when the external contact is cleared."
        --#SUMMARY "Alarm #001: %s.  Slot: %d  Event type: %d  Severity: %d  Instance: %d  Sequence: #%d"
        --#ARGUMENTS {4,7,1,5,3,0}
        --#SEVERITY MAJOR
        --#TIMEINDEX 10
        --#STATE OPERATIONAL
   ::= { msTraps 11 }
// 这个主意NOTIFICATION-TYPE,其定义了一个Trap消息,还定义了该trap消息中的内容是使用了AlarmTable中的内容。

 好了基本上一个网元在设计的时候都是先去申请OID节点,然后设计这个MIB文件座位开发的标准。

然后我们使用MibBrowser导入它。

下载安装MibBrowser打开它。



 

点击File->Load MIBS,选择一个mib文件打开就会得到上面的样子了。

我们再来看看其他功能。

1. get


  • 在左树中选择要操作的节点,
  • 最上面Address中输入网元地址,这里是笔者自己写的一个模拟器,后面会把模拟器的代码奉上。
  • Advanced可以设置SNMP的版本,一个用来身份验证的Community和端口
  • Operations选择为Get,此外还能选择为Getnext walk等。 点击Go.截图没截到
  • 这样就完成了一个请求操作,在后下的列表中会返回结果

2. getNext

    与1相同,只是Operations设置为GetNext

3. walk

    与1相同,Operations设置为walk,这个的返回结果会是一个列表。会默认轮询调用getNext获取整个Mib结构的所有值。

   

 

4, trapReceiver

打开TrapReceiver. Tool->Trap Receiver.

 按照5中的方式发送Trap

然后看到结果:



 

5. trapSender

发送TrapSender

右击一个NOTIFICATION-TYPE的对象选择Send Trap.



 输入一些信息,点击SendTrap,在4中看结果

好了基本就这么多的功能了,因为SNMP本身就是很简单的协议。这些功能也是我们之后在开发中要用代码实现的。

Linux SNMP服务

这个有可能需要安装,也是比较好用的。主要的命令格式是:

snmpget -v2c -c CONV 10.85.134.194 .1.3.6.1.2.1.1.1.0

snmpwalk -v2c -c CONV 10.32.147.19:10161 1.3.6.1.4.1.7569.1.2.1.28.1

这个一看明了了吧, -v2c是版本, -c是Community, 然后是ip:port oid.

Linux上开发必备

SNMP4J

 这个是下一篇要说的内容,是基于Java的开源的开发SNMP的包。下一篇具体说。

猜你喜欢

转载自wangzijian777.iteye.com/blog/2073476