zoukankan      html  css  js  c++  java
  • MIB snmp

    1  MIB基础知识

    MIBManagement Information Base,管理信息库)是MOManaged Object管理对象)定义的集合。MIB文件是按照ASN.1定义的文本文件。

     每个管理对象都对应一个节点,并且用OID(Object Identifier)来标识;数据管理对象对应叶子节点;所有的管理对象形成了一棵管理树。

    1.1 基本概念

    对象标识:对象标识是一种数据类型,它指明一种授权命名的对象。表示为一个整数序列,以点分隔。

    MIB树:表示对象标识的整数构成一个树型结构,类似于DNS和文件系统。

    对象标识从顶部开始,顶部没有标识,以root表示。所有的MIB变量都从1.3.6.1.2.1这个标识开始。树上的每个节点还有文字名,例如:1.3.6.1.2.1就和iso.org.dod.internet.memt.mib对应。

     图管理信息库的对象命名举例

    1.2  MIB分类

    MIB依据数据的通用性可以分为:

    1)标准MIBrfc1213, rfc1471 , rfc1724, rfc2618等等

       注: 通用性MIB rfc1213习惯称为MIB-II

    2)自定义MIB:当标准MIB信息不足以描述厂商设备,需要自定义MIB,但首先要向IANA组织申请编号。

    1.3 MIB管理对象的基本属性

    管理对象的四个基本属性如下:

    1)对象类型(Object Type):定义了一个特定对象的名字,例如sysUpTime。这个名字只是一个标示符。MIB对象既可以用这个标示符来表示,也可以用相应的MIB号码来表示。例如定义internet OBJECT IDENTIFIER ::= { iso org(3) dod(6) 1 }

    那么既可以用internet也可以用字串 .1.3.6.1来表示这个对象。

    2)语法(Syntax) :指定了数据类型,例如整数、8位组串数字(字符串;范围为0255)、对象标识符(预先定义的数据类型别名)或NULLNULL是留待的后使用的空位。

    3)访问(Access):表明了这个特定对象的访问级别。合法的值有:只读、读写、只写和不可存取。

    4)状态(Status):定义了这个对象的实现需要:必备的(被管理节点必须实现该对象);可选的(被管理对象可能实现该对象):或者已废弃的(被管理设备不需要再实现该对象)

    1.4  MIB两种对象类型

    1)标量(Type-Specific Objects):

    sysDescr OBJECT-TYPE

         SYNTAX DisplayString (SIZE(0..255))::= {system 1}

    OID: mib-2.system.1.0

    2)表量(Columnar Objects):

    OID:

    mib-2.interface.ifTable.ifEntry.ifDescr.2

    mib-2.interface.ifTable.ifEntry.ifDescr.6

    mib-2.interface.ifTable.ifEntry.ifType.2

    mib-2.interface.ifTable.ifEntry.ifType.6

    2  自定义MIB

        自定义MIB包含的内容有:模块级别信息、对象定义(OBJECT TYPE,包括标量对象和表对象)、陷阱定义(TRAP TYPE)。

    1行是MIB开始

    2-7行引入外部定义

    8-13行是模块信息定义

    19-28行是MO定义

    30-36行是TRAP定义

    37行是MIB结束

    2.1  常用对象类型

    v1中的

    1)简单类型:IntegerOctet StringObject IdentifierNull

    2)应用类型:IpAddressCounterGaugeTimeTicksOpaque

    v2中的

    1)简单类型:Integer32OctetStringObject IdentifierNull

    2)应用类型:IpAddressCounter32Counter64Gauge32Unsigned32TimeTicksOpaqueBIT STRING

    2.2  自定义MIB基本原则

    1)优先采用标准MIB:如果确实无法满足要求才考虑自定义MIB

    2)采用最新的SNMPV2SMI来定义MIB:使用最新的SNMPv2定义MIB可以使得对MIB的描述更详尽,可用的类型也更丰富。

    3)层次清晰,定义时顺序合理

            — 先定义根节点。

            — 在定义对象前,如有自定义类型,应当先书写自定义类型的定义。

            — 先定义标量对象,再表量对象。

    4)符合惯例,以标准MIB为参考

    3 理解和掌握ASN.1句法

    3.1  对象标识符 类型(OBJECT IDENTIFIER

    ASN.1中,对象标识符 类型 描述对象的抽象信息,MIB树中的每一个标号是用对象标识符描述的。由于树的各个分支是用数值表示的,所以实际上对象标识符是一个整数数值的序列。它用OBJECT IDENTIFIER来声明,如:

    myBranch OBJECT IDENTIFIER ::= { parentBranch 10 }

    其中myBranch是一个子树支,它定义在parentBranch树支下,“10”是子树myBranch在父树支parentBranch下的一个唯一对象标识符,即通常所说的OID。在parentBranch树支下,可以定义多个子树支,但子树支的名字和数字(如上的10)不能重复,即必须是唯一的。

    3.2  标量(叶子)对象标识符——简单变量

    在一个树支下,读者可以定义多个子树,也可以定义被管理资源的管理对象,其定义的句法如下:

    (objectname) OBJECT-TYPE

    SYNTAX (syntax)

    ACCESS (access)

    STATUS (status)

    DESCRIPTION (description)

    ::= { (parent) (number) }

             

     sysContact OBJECT-TYPE

                  SYNTAX  DisplayString (SIZE (0..255))

                  ACCESS  read-write

                  STATUS  mandatory

                  DESCRIPTION

                          "The textual identification of the contact person

                          for this managed node, together with information

                          on how to contact this person."

                  ::= { system 4 }

       以上的各部分解释如下:

    1(objectname). 这是被对象的名字,ASN.1句法要求所有对象的名字必须以小写字母开头,而且该名字在MIB中必须是唯一的。

    2OBJECT-TYPE.这是一个每一个叶子对象的所必须的关键字。

    3SYNTAX.被管对象类型的关键字,说明随后跟着的是一个类型。

    4(syntax).被管对象的类型,ASN.1句法要求所有的对象类型必须以大写字母开头,其中已预定义了的类型有CounterGaugeDisplayStringINTEGER等等,请参阅“3.对象语法定义”及“5.ASN.1的派生类型”。

    5ACCESS.被管对象的访问方式的关键字。在SNMP第二版中为MAX-ACCESS关键字。

    6(access).被管对象的访问方式,可为如下列举值中之一:read-onlyread-write、 no-accessibleSNMP2版中又新增了read-create

    7STATUS.被管对象的状态的关键字。

    8(status).可取的值为:mandatory optionalobsoletedeprecateSNMP1版中),currentobsoletedeprecateSNMP2版)。

    其中:mandatory为该对象的状态是必备的

    optional为该对象的状态是可选的

    obsolete为该对象的状态是不再使用

    deprecate使用该值使得MIB的某些部分标记为过时,被标记为“废弃”的对象将从现行版本中删除,并在新的MIB版本中标记为“过时”。

    current为该对象的状态是当前可用的。

    7DESCRIPTION.对被管对象的功能、特征等等进行描述的关键字。

    8)(description.被管对象的文本描述。须用双引号把其文本说明括起来,有时由于用MIB编译器编译结果太大时,可以把文本说明删除,即只保留一个空的双引号。

    9)(parent.包含此叶子对象的树支,即叶子对象的父亲必须是用“OBJECT IDENTIFIER”声明。

    10)(number.在此父树支下的第几个叶子对象,这个数字在此父树支下必须是唯一的。一般number都是从取1开始的。例如:“::={ myObject 22 }”,则在myObject树支下22必须是唯一的,否则在用MIB编译器(如pSOS所提供的MIB编译器)进行编译时会提示有错。

    除此之外,还有一些关键字:UNITSINDEXREFERENCEDEFVAL等等,分别代表被管对象的单位、索引、参考、缺省值。这些关键字都并不是很重要,有兴趣的读者可参阅RFC1155的说明。值得注意的是INDEX关键字在表对象定义中必须存在的,否则表内的对象不能使用。

    3.3  表类型  

    SNMP表是一个特殊类型的声明,表内声明的对象称为列对象,声明如下:  

    (tablename) OBJECT-TYPE 

    SYNTAX SEQUENCE OF (tabletype) 

    ACCESS not-accessible

     STATUS  mandatory  

    DESCRIPTION (description)

     ::= { (parent) (number) } 

     

     (entryname) OBJECT-TYPE  

    SYNTAX (tabletype) 

    ACCESS not-accessible 

    STATUS  mandatory  

    DESCRIPTION (description) 

    ::= { (tablename) 1 }   

     

    (tabletype) ::= SEQUENCE {  

    (column1) (column1type),

    (column2) (column2type),

     (columnN) (columnNtype) }   

    读者也许注意到(tablename)和(entryname)中的ACCESSnot-accessible,这是因为表和行对象没有叶子对象,因此不能被SNMP访问。ASN.1句法中关于定义一个表的规则如下: 

     (1 在表名(tablename)的命名中,必须要有一个“Table”关键字,例如定义一 个表对象“myTable  

    2 同样,在表对象下面的表目(entryname)也须有一个“Entry”关键字,例如 “myEntry”。  

    3 column1)是表的列对象,(column1type)是此列对象的类型 为了加深理解,举个

    子如下:

     myTable  OBJECT-TYPE  

    SYNTAX  SEQUENCE OF MyEntry  

    ACCESS  not-accessible 

     STATUS  mandatory  

    DESCRIPTION    " 这是一个表名为myTable的表对象. "  ::={ myParent 1 } 

     

      myEntry  OBJECT-TYPE 

     SYNTAX  MyEntry 

     ACCESS  not-accessible  

    STATUS  mandatory  

    DESCRIPTION 

       " 这是一个表的表目,其中INDEX关键字必须存在,它的索引值为列对象中的第一个对象"

      INDEX  {myIndex } 

     ::={ myTable 1 }  

     

     MyEntry::=  

    SEQUENCE  { 

    myIndex  INTEGER,     

    myColumn1  INTEGER,     

    myColumn2  OCTET STRING,      }    

    上表中有三个列对象myIndexmyColumn1myColumn2

     

     

    源码如下:

    XXX-TEST-MIB DEFINITIONS ::= BEGIN

    IMPORTS

    enterprises

                FROM RFC1155-SMI

            Integer32

                FROM SNMPv2-SMI            

            DisplayString

                FROM SNMPv2-TC;

      

       xxx OBJECT IDENTIFIER ::= {enterprises 22566}

      

       zkClassInfoTable OBJECT IDENTIFIER ::= {xxx 1}  

       zkClassInfoTable2 OBJECT IDENTIFIER ::= {xxx 2}  

      

    zkClassInfoTable OBJECT-TYPE 

    SYNTAX   SEQUENCE OF ZkClassInfoEntry 

       MAX-ACCESS not-accessible

       STATUS  current

       DESCRIPTION 

       "

       This is test table.

       "

            ::= {xxx 1}

      

       zkClassInfoEntry OBJECT-TYPE 

       SYNTAX    ZkClassInfoEntry 

       MAX-ACCESS  not-accessible    

       STATUS  current

       DESCRIPTION

       "

       This is teat entry.

       "     

       INDEX  {zkClassInfoIndex}             

       ::= {zkClassInfoTable 1}   

      

    ZkClassInfoEntry ::= SEQUENCE {

    zkClassInfoIndex  Integer32,

        zkClassInfoSex Integer32,

        zkClassInfoAge Integer32,

        zkCLassInfoName  DisplayString,

        zkClassInfoAddress  DisplayString

    }

     

    zkClassInfoIndex OBJECT-TYPE 

    SYNTAX  Integer32

    MAX-ACCESS read-write

    STATUS current

    DESCRIPTION 

    "

    "

    ::= {zkClassInfoEntry 1}

     

    zkClassInfoSex OBJECT-TYPE

    SYNTAX  Integer32  {

                  man(1),

                  woman(2)

    }

    MAX-ACCESS read-write

    STATUS current

    DESCRIPTION 

    "

    "

    ::= {zkClassInfoEntry 2}   

     

    zkClassInfoAge OBJECT-TYPE 

    SYNTAX  Integer32

    MAX-ACCESS read-write

    STATUS current

    DESCRIPTION 

    "

    "

    ::= {zkClassInfoEntry 3} 

     

    zkCLassInfoName OBJECT-TYPE 

    SYNTAX  DisplayString

    MAX-ACCESS read-write

    STATUS current

    DESCRIPTION 

    "

    "

    ::= {zkClassInfoEntry 4}

     

    zkClassInfoAddress OBJECT-TYPE 

    SYNTAX  DisplayString

    MAX-ACCESS read-write

    STATUS current

    DESCRIPTION 

    "

    "

    ::= {zkClassInfoEntry 5}   

     

    zkClassInfoTable2 OBJECT-TYPE 

    SYNTAX   SEQUENCE OF ZkClassInfoEntry2 

       MAX-ACCESS not-accessible

       STATUS  current

       DESCRIPTION 

       "

       This is test table.

       "

            ::= {xxx 2}

      

       zkClassInfoEntry2 OBJECT-TYPE 

       SYNTAX    ZkClassInfoEntry2 

       MAX-ACCESS  not-accessible    

       STATUS  current

       DESCRIPTION

       "

       This is teat entry.

       "     

       INDEX  {zkClassInfoIndex}             

       ::= {zkClassInfoTable2 1}   

      

    ZkClassInfoEntry2 ::= SEQUENCE {

        zkClassInfoSex2 Integer32,

        zkClassInfoAge2 Integer32,

        zkCLassInfoName2  DisplayString,

        zkClassInfoAddress2  DisplayString

    }

     

    zkClassInfoSex2 OBJECT-TYPE 

    SYNTAX  Integer32

    MAX-ACCESS read-write

    STATUS current

    DESCRIPTION 

    "

    "

    ::= {zkClassInfoEntry2 1}

    END

     

    XXX-TEST_MIB DEFINITIONS ::= BEGIN

    IMPORTS

    enterprises

                FROM RFC1155-SMI

            Integer32

                FROM SNMPv2-SMI            

            DisplayString

                FROM SNMPv2-TC;

      

       xxx OBJECT IDENTIFIER ::= {enterprises 40256}

      

       zkClassInfoTable OBJECT IDENTIFIER ::= {xxx 1}  

       zkClassInfoTable2 OBJECT IDENTIFIER ::= {xxx 2}  

      

    zkClassInfoTable OBJECT-TYPE 

    SYNTAX   SEQUENCE OF ZkClassInfoEntry 

       MAX-ACCESS not-accessible

       STATUS  current

       DESCRIPTION 

       "

       This is test table.

       "

            ::= {xxx 1}

      

       zkClassInfoEntry OBJECT-TYPE 

       SYNTAX    ZkClassInfoEntry 

       MAX-ACCESS  not-accessible    

       STATUS  current

       DESCRIPTION

       "

       This is teat entry.

       "     

       INDEX  {zkClassInfoIndex}             

       ::= {zkClassInfoTable 1}   

      

    ZkClassInfoEntry ::= SEQUENCE {

    zkClassInfoIndex  Integer32,

        zkClassInfoSex Integer32,

        zkClassInfoAge Integer32,

        zkCLassInfoName  DisplayString,

        zkClassInfoAddress  DisplayString

    }

     

    zkClassInfoIndex OBJECT-TYPE 

    SYNTAX  Integer32

    MAX-ACCESS read-write

    STATUS current

    DESCRIPTION 

    "

    "

    ::= {zkClassInfoEntry 1}

     

    zkClassInfoSex OBJECT-TYPE

    SYNTAX  Integer32  {

                  man(1),

                  woman(2)

    }

    MAX-ACCESS read-write

    STATUS current

    DESCRIPTION 

    "

    "

    ::= {zkClassInfoEntry 2}   

     

    zkClassInfoAge OBJECT-TYPE 

    SYNTAX  Integer32

    MAX-ACCESS read-write

    STATUS current

    DESCRIPTION 

    "

    "

    ::= {zkClassInfoEntry 3} 

     

    zkCLassInfoName OBJECT-TYPE 

    SYNTAX  DisplayString

    MAX-ACCESS read-write

    STATUS current

    DESCRIPTION 

    "

    "

    ::= {zkClassInfoEntry 4}

     

    zkClassInfoAddress OBJECT-TYPE 

    SYNTAX  DisplayString

    MAX-ACCESS read-write

    STATUS current

    DESCRIPTION 

    "

    "

    ::= {zkClassInfoEntry 5}   

     

    zkClassInfoTable2 OBJECT-TYPE 

    SYNTAX   SEQUENCE OF ZkClassInfoEntry2 

       MAX-ACCESS not-accessible

       STATUS  current

       DESCRIPTION 

       "

       This is test table.

       "

            ::= {xxx 2}

      

       zkClassInfoEntry2 OBJECT-TYPE 

       SYNTAX    ZkClassInfoEntry2 

       MAX-ACCESS  not-accessible    

       STATUS  current

       DESCRIPTION

       "

       This is teat entry.

       "     

       INDEX  {zkClassInfoIndex}             

       ::= {zkClassInfoTable2 1}   

      

    ZkClassInfoEntry2 ::= SEQUENCE {

        zkClassInfoSex2 Integer32,

        zkClassInfoAge2 Integer32,

        zkCLassInfoName2  DisplayString,

        zkClassInfoAddress2  DisplayString

    }

     

    zkClassInfoSex2 OBJECT-TYPE 

    SYNTAX  Integer32

    MAX-ACCESS read-write

    STATUS current

    DESCRIPTION 

    "

    "

    ::= {zkClassInfoEntry2 1}

    END

     

  • 相关阅读:
    计算机学习—系统优化(1)
    B站Vue教学视频-个人随笔笔记-(031-040)
    B站Vue教学视频-个人随笔笔记-(021-030)
    B站Vue教学视频-个人随笔笔记-(011-020)
    B站Vue教学视频-个人随笔笔记-(001-010)
    Docker入门(三):容器(Containers)
    WinDBG符号路径设置
    Docker入门(二):安装/卸载
    Docker入门(一):简介
    CentOS下安装配置Samba服务器
  • 原文地址:https://www.cnblogs.com/sheng1255blog/p/4129422.html
Copyright © 2011-2022 走看看