SNMP协议在设备监控中的使用

京东云开发者
• 阅读 0

随着网络技术的飞速发展,网络管理变得日益重要。网络管理员需要一种高效、可靠的方式来监控网络设备、收集状态信息并对其进行配置。简单网络管理协议(SNMP)正是为此目的而设计的。本文将对SNMP进行详细介绍,并提供使用SNMP进行网络管理的基本指南。

1.简介

SNMP(Simple Network Management Protocol)是一个基于互联网协议族(IP)的网络管理标准,用于在IP网络中的管理节点与被管理节点之间进行通信,以实现对网络设备的远程监控和管理。SNMP具有简单、高效、易于实现和扩展性强等优点,因此在网络管理领域得到了广泛应用。

2.SNMP的组成和版本

2.1.SNMP协议的组成

SNMP协议架构主要包括以下几个部分: SNMP协议在设备监控中的使用





1.管理信息库(MIB) :MIB是一个信息数据库,用于存储被管理设备的信息,如设备类型、接口状态、路由表等。MIB是SNMP的核心,管理站通过SNMP协议获取MIB中的信息,以实现对网络设备的监控和管理。

2.管理站(NMS) :NMS是网络管理系统中的核心组件,负责收集、处理和存储来自被管理设备的信息。NMS通常运行在网络管理中心的服务器上,通过网络管理软件实现对网络设备的远程监控和管理。

3.代理(Agent) :Agent是被管理设备上的软件模块,负责接收NMS的查询请求,并返回MIB中的相关信息。同时,Agent还可以将设备的状态变化通知给NMS。

2.2.SNMP协议版本

目前SNMP协议有三个版本,分别是:V1、V2和V3

•V1:SNMP协议的最初版本

•V2:在V1的基础上增加community(团体名),这里的团体名可以理解为密码

•V3:增加认证和对密文的传输的支持,这种方式安全等级最高

3.SNMP报文



SNMP协议在设备监控中的使用



SNMP报文包含三个部分

•版本号:表明当前使用的版本,管理站和代理之间的版本号必须相同才能通信

•团体名:团体(community)是基本的安全机制,用于实现SNMP网络管理员访问SNMP管理代理时的身份验证,类似于密码,默认值为 public。团体名(Community name)是管理代理的口令,管理员被允许访问数据对象的前提就是网络管理员知道网络代理的口令。

•PDU:snmp的数据结构

3.1.PDU详细报文



SNMP协议在设备监控中的使用



3.2.PDU类型

•get-request:从代理(本质上是设备)获取一个或多个参数值

•get-next-request:从代理紧接着取出下一个参数值

•set-request:设置代理一个或多个参数值

•get-response:对上述三种请求的响应

•trap:设备主动上报的数据

3.3.差错状态

•noError:无错误

•tooBig:代理无法将回答装入到一个SNMP报文中

•noSuchName:操作指明了一个不存在的变量

•badValue:一个set操作指明了一个无效值或无效语法

•readOnly:管理进程试图修改一个只读变量

•genErr:某些其他差错

3.4.trap类型

•coldStart:代理进行了初始化

•warmStart:代理进行了重新初始化

•linkDown:一个接口从工作状态变为故障状态

•linkUp:一个接口从故障状态变为工作状态

•authenticationFailure:从SNMP管理进程接收到具有一个无效共同体的报文

•egpNeighborLoss:一个EGP相邻路由器变为故障状态

•enterpriseSpecific:代理自定义事件,需要用后面的“特定代码”来指明

4.MIB详解

4.1.MIB树结构

MIB以树状结构进行存储,树的叶子节点表示管理对象,它可以通过从根节点开始的一条惟一路径来识别,这也就是OID(Object Identifier)。

SNMP协议在设备监控中的使用



OID是由一些系列非负整数组成,用于唯一标识管理对象在MIB树中的位置。由SMI来保证OID不会冲突。

MIB文件一旦发布,OID就和被定义的对象绑定,不能修改。MIB节点不能被删除,只能将它的状态置为“obsolete”,表明该节点已经被废除。

在上图的树形结构中,mgmt对象可以标识为:{ iso(1) org(3) dod(6) internet(1) mgmt(2) },简单标记为:1.3.6.1.2,这种标识就叫做OID。

NMS通过OID引用Agent中的对象。

4.2.MIB分类

MIB可以分为公有MIB和私有MIB两种。

•公有MIB:一般由RFC定义,主要用来对各种公有协议进行结构化设计和接口标准化处理。大多数的设备制造商都需要按照RFC的定义来提供SNMP接口。

•私有MIB:是公有MIB的必要补充,当公司自行开发私有协议或者特有功能时,可以利用私有MIB来完善SNMP接口的管理功能,同时对第三方网管软件管理存在私有协议或特有功能的设备提供支持。

网络设备的很多数据都以MIB的树结构存储,根据数据对应的OID,我们便可以获取到网络设备的各种统计数据和配置数据,实现网络设备的监控。

5.SNMP实践

5.1.snmp命令

5.1.1.snmpwalk

用于获取 SNMP 设备上的数据,它遍历设备的 SNMP 树,并返回特定对象标识符(OID)的值,通常用于查询设备的信息和状态。使用 snmpwalk 可以获取有关设备的详细信息,例如接口、系统信息、传感器状态等。以下是 snmpwalk 的一般用法:

snmpwalk -v SNMP_VERSION -c COMMUNITY_STRING TARGET_HOST OID
SNMP_VERSION:SNMP 版本,通常是 "1"(SNMPv1)或 "2c"(SNMPv2c)。
COMMUNITY_STRING:SNMP 社区字符串,用于身份验证。
TARGET_HOST:目标设备的主机名或 IP 地址。
OID:要查询的对象标识符。

5.1.2.snmptrap

snmptrap 用于生成和发送 SNMP 陷阱(trap)到 SNMP 管理器,这些陷阱通常表示设备上发生的重要事件或告警。snmptrap 常用于监控设备状态变化和异常事件。以下是 snmptrap 的一般用法:

snmptrap -v SNMP_VERSION -c COMMUNITY_STRING TARGET_HOST TRAP_OID [OID_VALUE] [OPTIONS]
SNMP_VERSION:SNMP 版本,通常是 "1"(SNMPv1)或 "2c"(SNMPv2c)。
COMMUNITY_STRING:SNMP 社区字符串,用于身份验证。
TARGET_HOST:目标 SNMP 管理器的主机名或 IP 地址。
TRAP_OID:陷阱的对象标识符,表示事件类型。
OID_VALUE:可选,与陷阱相关的 OID 值。
OPTIONS:可选,包括发送陷阱的其他选项,如 -p(指定陷阱端口)等。

5.1.3.snmpget

用于获取单个 SNMP 对象的值。你可以指定要查询的 OID,它将返回相应的值。

snmpget -v SNMP_VERSION -c COMMUNITY_STRING TARGET_HOST OID

snmpget -v SNMP_VERSION -c COMMUNITY_STRING TARGET_HOST OID

5.1.4.snmpset

用于设置 SNMP 对象的值。它允许你修改设备上的特定 OID 的值。

snmpset -v SNMP_VERSION -c COMMUNITY_STRING TARGET_HOST OID TYPE VALUE

5.1.5.snmpbulkwalk

类似于 snmpwalk,但它使用了 SNMP Bulk Protocol(SNMPv2c)来提高效率,特别对于大型数据集。

snmpbulkwalk -v SNMP_VERSION -c COMMUNITY_STRING TARGET_HOST OID

5.1.6.snmpinform

用于向 SNMP 管理器发送 SNMP INFORM 消息,这是一种更可靠的通知机制,它需要管理器进行确认。

snmpinform -v SNMP_VERSION -c COMMUNITY_STRING TARGET_HOST OID

在网络设备信息采集中,我们通常会通过snmpget和snmpwalk命令获取网络设备的各种运行和配置数据。

5.2.代码实现

基于以上知识,我们考虑通过代码的方式执行snmp命令,获取设备的基本信息,实现设备的自动化监控。本文所有案例都基于Java语言,其余语言类似。

5.2.1.引入依赖

如下所示,我们引入snmp的依赖:

<dependency>
   <groupId>org.snmp4j</groupId>
   <artifactId>snmp4j</artifactId>
   <version>2.7.0</version>
</dependency>

5.2.1.代码实现

public class SnmpUtils {

    /**
     * 根据oid获取数据
     * @param ip
     * @param community
     * @param oid
     * @return
     */
    @SneakyThrows
    public static void snmpGet(String ip, String community, String oid) {

        Snmp snmp = null;
        try {

            snmp = new Snmp(new DefaultUdpTransportMapping()); // 构造一个UDP
            snmp.listen(); // 开始监听snmp消息

            CommunityTarget target = new CommunityTarget();
            target.setCommunity(new OctetString(community));// snmpv2的团体名
            target.setVersion(SnmpConstants.version2c); // snmp版本
            target.setAddress(new UdpAddress(ip));
            target.setTimeout(1000); // 时延
            target.setRetries(2); // 重传

            PDU pdu = new PDU();
            pdu.setType(PDU.GET);
            pdu.addOID(new VariableBinding(new OID(oid)));

            ResponseEvent responseEvent = snmp.get(pdu, target);
            PDU response = responseEvent.getResponse();
            Vector<? extends VariableBinding> bindings = response.getVariableBindings();
            bindings.forEach(item ->{
                System.out.println(String.format("OID为:%s的值为:%s", item.getOid().toDottedString(), item.getVariable().getSyntaxString()));
            });

        }finally {
            if (snmp != null) {
                snmp.close();
            }
        }
    }

    /**
     * 根据oids获取数据
     * @param ip
     * @param community
     * @return
     */
    @SneakyThrows
    public static void getTable(String ip, String community, List<String> oidList)
    {
        Snmp snmp = null;
        LinkedHashMap<String, List<String>> resMap = new LinkedHashMap<>();
        try {

            snmp = new Snmp(new DefaultUdpTransportMapping()); // 构造一个UDP
            snmp.listen(); // 开始监听snmp消息

            CommunityTarget target = new CommunityTarget();
            target.setCommunity(new OctetString(community));// snmpv2的团体名

            target.setVersion(SnmpConstants.version2c); // snmp版本

            target.setAddress(new UdpAddress(ip));
            target.setTimeout(1000); // 时延
            target.setRetries(2); // 重传

            TableUtils utils = new TableUtils(snmp, new DefaultPDUFactory(
                    PDU.GETNEXT));// GETNEXT or GETBULK
            utils.setMaxNumRowsPerPDU(109); // only for GETBULK, set max-repetitions, default is 10

            utils.setCheckLexicographicOrdering(false);

            OID[] oids = oidList.stream().filter(StringUtils::isNotBlank).map(OID::new).toArray(OID[]::new);

            List<TableEvent> table = utils.getTable(target, oids, null, null);
            table.forEach(item ->{
                for (VariableBinding column : item.getColumns()) {
                    System.out.println(String.format("当前的oid为:%s,结果为:%s", column.getOid().toDottedString(), column.getVariable().getSyntaxString()));
                }
            });
        }finally {
            if (snmp != null) {
                snmp.close();
            }
        }
    }
}

其中snmpGet方法对应snmpget命令,snmpWalk方法对应snmpwalk命令。

6.总结

本文开篇即对SNMP(简单网络管理协议)的基本概念与核心构成进行了全面阐述,紧接着深入剖析了SNMP命令在实际网络管理场景中的具体应用。在文章的最后部分,通过Java编程语言的实践应用,本文成功展示了SNMP命令的实现过程。对SNMP协议的深入理解与掌握,无疑将为网络设备的数据监控及多元化自动化管理提供有力支持,进而显著提升网络运维的工作效率。

点赞
收藏
评论区
推荐文章
Wesley13 Wesley13
3年前
SNMP协议
SNMP是专门设计用于在IP网络管理网络节点(服务器、工作站、路由器、交换机及HUBS等)的一种标准协议,它是一种应用层协议。SNMP使网络管理员能够管理网络效能,发现并解决网络问题以及规划网络增长。通过SNMP接收随机消息(及事件报告)网络管理系统获知网络出现问题。SNMP的前身是简单网关监控协议(SGMP),用来对通信线路进行管理。随后
Stella981 Stella981
3年前
Linux 中的 DHCP 原理
导读DHCP(DynamicHostConfigurationProtocol,动态主机配置协议)是一个局域网的网络协议,使用UDP协议工作,主要有两个用途:给内部网络或网络服务供应商自动分配IP地址、子网掩码、网关以及DNS、(网络批量安装)等tcp/ip信息,给用户或者内部网络管理员作为对所有计算机作中央管理的方法。DHCP原
Stella981 Stella981
3年前
Android Volley完全解析(一),初识Volley的基本用法
1\.Volley简介我们平时在开发Android应用的时候不可避免地都需要用到网络技术,而多数情况下应用程序都会使用HTTP协议来发送和接收网络数据。Android系统中主要提供了两种方式来进行HTTP通信,HttpURLConnection和HttpClient,几乎在任何项目的代码中我们都能看到这两个类的身影,使用率
Wesley13 Wesley13
3年前
RHEL7
使用DHCP动态管理主机地址动态主机地址管理协议DHCP是一种基于UDP协议且仅限在局域网内部使用的网络协议,主用于大型的局域网环境或者存在较多移动设备的局域网中;DHCP协议根据作用域来管理网络的分布;作用域一个完整的IP地址段,DHCP协议根据作用域来管理网络的分布,分配IP及配置参数;超级作用域管理处于同一个物理网
四种网络监控类型
网络监控可以采用多种形式,具体取决于需要监控的内容。随着网络架构变得更加以软件为中心和去中心化从混合云和多云的角度来看,网络团队可能会发现难以理解各种类型的网络监控方法和工具。下面让我们看一下四种网络监控类型,以及特定的机制和协议,它们可提供企业所需的适当级别的可见性。可用性监控可用性监控是网络团队了解设备是否正常运行的最简单方法。有些可用性监控工具不只是监
SDN网络技术在云计算中的应用
SDN(软件定义网络)是一种新型的网络架构,其基本思想是将数据平面和控制平面分离,通过集中式的控制器来管理网络流量。传统的网络架构由路由器、交换机等网络设备组成,这些设备通常具有固定功能和配置,难以满足大规模、复杂的网络需求。因此,SDN技术提出了一种全新的网络设计理念,旨在提高网络的灵活性、可扩展性和安全性。
流浪剑客 流浪剑客
1年前
Macos http调试代理工具:Proxyman for mac
是一款功能强大的网络代理工具软件,适用于Mac和iOS平台。它可以帮助开发人员、测试人员和网络管理员监控和调试网络流量。以下是Proxyman软件的一些主要功能和特点:流量捕获和监控:Proxyman可以捕获并显示设备上的所有网络流量,包括HTTP、HTT
绣鸾 绣鸾
1年前
Proxyman for mac(HTTP调试代理工具)
是一款功能强大的网络代理工具软件,适用于Mac和iOS平台。它可以帮助开发人员、测试人员和网络管理员监控和调试网络流量。以下是Proxyman软件的一些主要功能和特点:流量捕获和监控:Proxyman可以捕获并显示设备上的所有网络流量,包括HTTP、HTT
流浪剑客 流浪剑客
1年前
http网络调试代理工具:Proxyman for Mac 中文版
是一款功能强大的网络代理工具软件,适用于Mac和iOS平台。它可以帮助开发人员、测试人员和网络管理员监控和调试网络流量。以下是Proxyman软件的一些主要功能和特点:流量捕获和监控:Proxyman可以捕获并显示设备上的所有网络流量,包括HTTP、HTT
绣鸾 绣鸾
1年前
SecureCRT for Mac(终端SSH工具)附注册码 v9.4.2正式版
是一款由VanDykeSoftware公司开发的终端仿真软件,它提供了类似于Telnet和SSH等协议的远程访问功能。SecureCRT专门为网络管理员、系统管理员和其他需要保密访问网络设备的用户设计。SecureCRT具有以下特点:安全性:SecureC