SNMP简介

news2024/11/30 12:28:01

背景

简单网络管理协议SNMP(Simple Network Management Protocol)用于网络设备的管理。网络设备种类多种多样,不同设备厂商提供的管理接口(如命令行接口)各不相同,这使得网络管理变得愈发复杂。为解决这一问题,SNMP应运而生。SNMP作为广泛应用于TCP/IP网络的网络管理标准协议,提供了统一的接口,从而实现了不同种类和厂商的网络设备之间的统一管理。

SNMP协议分为三个版本:SNMPv1、SNMPv2c和SNMPv3。

协议安全性其他差异
SNMPv1基于团体名认证,安全性较差初始化版本
SNMPv2c基于团体名认证,安全性较差在SNMPv1版本的基础上引入了GetBulk和Inform操作,支持更多的标准错误码信息,支持更多的数据类型(Counter64、Counter32)。
SNMPv3模块化方法,允许调整安全性。

常见的认证方式:
基于USM(User Security Module)的认证加密,
基于VACM(View-based Access Control Model)的访问控制.

具体见安全性章节
支持的操作同SNMPv2c相同

架构

SNMP系统由以下四部分组成:

名称说明
NMS(Network Management System)网络中的管理者,是一个采用SNMP协议对网络设备进行管理/监视的系统,运行在NMS服务器上。
SNMP Agent被管理设备中的一个代理进程,用于维护被管理设备的信息数据并响应来自NMS的请求,把管理数据汇报给发送请求的NMS。
MIB(Management Information Base)一个数据库,指明了被管理设备所维护的变量。MIB在数据库中定义了被管理设备的一系列属性:对象的名称、对象的状态、对象的访问权限和对象的数据类型等。
Management object被管理对象。每一个设备可能包含多个被管理对象,被管理对象可以是设备中的某个硬件,也可以是在硬件、软件(如路由选择协议)上配置的参数集合。

在这里插入图片描述

MIB 设计

MIB是以树状结构进行存储的。树的节点表示被管理对象,它可以用从根开始的一条路径唯一地识别,这条路径就称为OID。

比如:system的OID为1.3.6.1.2.1.1

在这里插入图片描述
用户可以配置MIB视图来限制NMS能够访问的MIB对象。MIB视图是MIB的子集合,用户可以将MIB视图内的对象配置为exclude或include。exclude表示当前视图不包含该MIB子树的所有节点;include表示当前视图包含该MIB子树的所有节点。

SNMP端口号

SNMP报文是普通的UDP报文,协议中规定有两个默认端口号:

端口号说明
161NMS发送Get、GetNext、GetBulk和Set操作请求以及SNMP Agent响应这些请求操作时,使用该端口号。
162SNMP Agent向NMS发送Trap或Inform时,使用该端口号。
该端口号支持用户配置,但是需要保证SNMP Agent发送Trap或Inform的端口号与NMS监听Trap或Inform的端口号要一致。

工作原理

方式说明
GET从网络节点检索数据
GETNEXT从网络节点检索下一个元素
SET向网络节点发送配置或控制命令
TRAP网络节点主动向管理站发送警报通知
INFORM已确认收到TRAP(如果没有收到确认,网络节点可以尝试再次发送)

安全性

SNMPv1 , SNMPv2c: 团体名认证(community strings)

SNMP在最初开发时采用团体名(使用了明文)进行认证,因此安全性较差,使用net-snmp中的工具snmpget可以查看到这些明文。

$ snmpget -d -v 2c -c demopublic test.net-snmp.org sysContact.0

Sending 47 bytes to UDP: [157.185.82.8]:161->[0.0.0.0]:0
0000: 30 2D 02 01 01 04 0A 64 65 6D 6F 70 75 62 6C 69 0-…demopubli
0016: 63 A0 1C 02 04 78 8E 32 C9 02 01 00 02 01 00 30 c…x.2…0
0032: 0E 30 0C 06 08 2B 06 01 02 01 01 04 00 05 00 .0…+…

Received 102 byte packet from UDP: [157.185.82.8]:161->[0.0.0.0]:47960
0000: 30 64 02 01 01 04 0A 64 65 6D 6F 70 75 62 6C 69 0d…demopubli
0016: 63 A2 53 02 04 78 8E 32 C9 02 01 00 02 01 00 30 c.S…x.2…0
0032: 45 30 43 06 08 2B 06 01 02 01 01 04 00 04 37 4E E0C…+…7N
0048: 65 74 2D 53 4E 4D 50 20 43 6F 64 65 72 73 20 3C et-SNMP Coders <
0064: 6E 65 74 2D 73 6E 6D 70 2D 63 6F 64 65 72 73 40 net-snmp-coders@
0080: 6C 69 73 74 73 2E 73 6F 75 72 63 65 66 6F 72 67 lists.sourceforg
0096: 65 2E 6E 65 74 3E e.net>

SNMPv2-MIB::sysContact.0 = STRING: Net-SNMP Coders net-snmp-coders@lists.sourceforge.net

SNMPv3: 动态模块化方法(modular approach)

RFCS 3410-3419针对SNMPv3定义了SNMPv3的模块化方法。这种模块化方法很重要,因为它被设计为允许协议在未来需要或首选其他类型的安全性时进行调整。
在这里插入图片描述

认证方式

协议+认证方式说明
SNMPv1 、 SNMPv2c无安全性可言。
SNMPv3+USM最初的SNMPv3安全模型。大多数设备都支持。
SNMPv3+TLS(或DTLS)通过TLS和DTLS隧道传输SNMP。希望很快得到大多数设备的支持。
SNMPv3+SSH通过SSH隧道传输SNMP(在Net-SNMP中并非100%支持)
SNMP+Kerberos使用Kerberos保护SNMP(很少支持这种方式)

如果完全使用Net-SNMP产品或支持TLS的产品,推荐使用SNMPv3 over(D)TLS
如果与旧版SNMPv3设备通信,需要使用 SNMPv3/USM
设备不能仅支持SNMPv1/SNMPv2c(没有安全性)

SNMPv3 + USM

最初的SNMPv3规范包括一个基于USM(User Security Module)的认证的安全模型,该模型通过允许管理员定义具有各种安全凭据的“用户”来保护协议。这对保护协议有很大帮助(尽管正如Wes Hardaker(Net SNMP的创始人)在一篇博客文章中所记录的那样,SNMPv3/USM仍然存在一些问题)。运营商还发现,保护SNMPv3/USM需要“另一个”密码数据库来维护,这在操作上是繁重的。
但SNMPv3/USM实现得相当广泛,大多数现代设备都会支持它。
有关将SNMPv3/USM与Net SNMP工具包一起使用的详细信息,请参阅SNMPv3/USM教程。

SNMPv3+TLS(或DTLS)

IETF关于SNMP安全性的最新活动已在SNMP集成安全模型(ISMS)工作组中完成。USM是创建了一个新的安全系统,但用户更愿意通过隧道传输SNMP。

相关RFC:

RFC说明
RFC5590简单网络管理协议的传输子系统
RFC5591简单网络管理协议(SNMP)的传输安全模型
RFC5592简单网络管理协议(SNMP)的安全外壳传输模型
RFC5608简单网络管理协议(SNMP)传输模型的远程身份验证拨入用户服务(RADIUS)用法。
RFC5953简单网络管理协议(SNMP)的传输层安全性(TLS)传输模型

这些RFC提供了通过SSH、TLS和DTLS对SNMPv3数据包进行隧道传输的框架。SSH协议使用现有的SSH身份验证和加密方法(如SSH密钥和/或用户名和密码)来保护其流量。TLS和DTLS协议使用X.509证书来保护其流量。

Net SNMP 5.6包含对通过TLS和DTLS使用SNMP的强大支持。有关通过TLS和DTLS设置和使用SNMP的详细信息,请参阅TLS教程。Net SNMP 5.6还包含对通过SSH使用SNMP的最低支持,但由于缺乏可用的SSH服务器端库,支持受到限制,并且在连接到OpenSSH sshd服务器时通过专门的shell“破解”实现。

有关使用SSH对性能影响的信息,参考Performance Analysis of SNMP over SSH(Pdf)和Performance Analysis of SNMP over SSH(PPT)。

Kerberos SNMPv3

Wes Hardaker和Ken Horstein开始在IETF中为SNMPv3实现kerberos安全模型。尽管Net SNMP包含了这方面的原型实现,但这项工作从未在IETF中完成,也从未在Net SNMP实现中完成,而且还没有准备好在现实中使用。

参考

什么是SNMP

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/527812.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

新车推迟、裁员降本,沃尔沃被现实狠狠“扇了一个耳光”

汽车行业的魅力&#xff0c;或许就在于不断的给自己打气&#xff0c;然后被打脸。 今年&#xff0c;上海车展开幕前&#xff0c;沃尔沃汽车大中华区销售公司总裁钦培吉在新车发布会上直言&#xff1a;“新势力会的&#xff0c;我们三年就学会了&#xff1b;我们会的&#xff0c…

无影云桌面,搭建一个属于自己的云上主机

无影云桌面&#xff0c;搭建一个属于自己的云上主机 1.无影云桌面介绍2.无影云桌面试用3.无影云桌面尝鲜4.测试云桌面的连通性5.体验无影云的娱乐办公场景6.将无影云桌面作为服务器使用7.无影云桌面使用总结 1.无影云桌面介绍 无影云桌面是一种云计算技术&#xff0c;可以将用…

《LKD3粗读笔记》(12)内存管理

1、页 内核把物理页作为内存管理的基本单元内存管理单元&#xff08;MMU&#xff09;以页为单位来管理系统中的页表从虚拟内存的角度看&#xff0c;页就是最小单位。体系结构不同&#xff0c;支持页的大小也不尽相同。大多数32位体系结构支持4KB的页&#xff0c;而64位体系结构…

排序算法之堆排序的实现

一、堆的相关概念 堆一般指的是二叉堆&#xff0c;顾名思义&#xff0c;二叉堆是完全二叉树或者近似完全二叉树 1. 堆的性质 ① 是一棵完全二叉树 ② 每个节点的值都大于或等于其子节点的值&#xff0c;为最大堆&#xff1b;反之为最小堆。 2. 堆的存储 一般用数组来表示堆&…

网站域名查询地址-域名所有者查询

域名查询注册信息查询 147SEO域名查询是一款全能的域名查询注册信息查询软件。它不仅提供了单个域名的实时查询功能&#xff0c;还支持批量域名查询功能&#xff0c;可以快速查询多个域名的注册和到期信息。以下是147SEO域名查询的主要特点&#xff1a; 批量域名查询&#xff…

基于【EasyDL】【图像分类】实现农作物病害识别小程序

内容、数据集来源:基于飞桨的农作物病害智能识别系统 - 飞桨AI Studio 项目背景 联合国粮食及农业组织的一份报告表明&#xff0c;每年农业生产的自然损失中有三分之一以上是由农业病虫害造成的&#xff0c;使这些成为当前影响农业生产和农业生产的最重要因素。需要考虑的农业…

浅谈Vue响应式

什么是响应式 不管是自己面试还是八股文告诉你的是&#xff0c;响应式描述的是视图与数据变化之间的一种关系。但这不够准确。 要要了解什么是响应式&#xff0c;我们必须了解不管是React,还是Vue其实本质就是一个函数。 那么我们可以形象的说&#xff1a;响应式描述的就是函数…

编译C++ makefile ZXing-cpp生成条型码 二维码及识别 再试验证成功vs2022

下载ZXing-cpp源码及vs2022 cmake --help看看支持的vs 为什么没有win32呢 进到目录&#xff0c;//新建编译目录//生成vs工程 mkdir build & cd build cmake .. 中间提示opencv和qt等缺东西不要紧&#xff0c;我只用到生成条型码 release也正常。生成成功。 默认是MD 先…

记一次 .NET 某医院门诊软件 卡死分析

一&#xff1a;背景 1. 讲故事 前几天有位朋友找到我&#xff0c;说他们的软件在客户那边卡死了&#xff0c;让我帮忙看下是怎么回事&#xff1f;我就让朋友在程序卡死的时候通过 任务管理器 抓一个 dump 下来&#xff0c;虽然默认抓的是 wow64 &#xff0c;不过用 soswow64.…

FreeRTOS学习笔记(四)——应用开发(二)

文章目录 0x01 互斥量互斥量的优先级继承机制互斥量应用场景互斥量运作机制互斥量控制块互斥量接口函数xSemaphoreCreateMutex()xQueueCreateMutex()prvInitialiseMutex&#xff08;&#xff09;xSemaphoreCreateRecursiveMutex()vSemaphoreDelete()xSemaphoreTake()xQueueSema…

通过nginx配置 将vue项目运行到阿里云linux服务器上

先将 我们的vue项目打包起来 打包好之后 我们在项目根目录下 找到 dist 下的 index.html 保证这个文件要能正常运行 然后 我们将这个dist文件夹 压缩一下 然后 回到项目终端 执行 scp -r ./dist.zip 用户名(如果之前没设置过就是 root)服务器公网地址:/root然后 他会要求我…

多语言网站的外包开发流程

随着互联网/移动互联网的全球普及&#xff0c;越来越多的企业希望将产品卖向全球&#xff0c;这就首先需要有一个多语言的网站来宣传公司的产品&#xff0c;那设计和开发这样的网站需要注意什么呢&#xff0c;今天和大家分享这方面的知识。北京木奇移动技术有限公司&#xff0c…

C-函数栈帧

文章目录 函数栈帧栈帧创建栈帧销毁根据栈帧关系更改值拓展 可变参数列表基本原理整形提升 命令行参数打印环境变量 函数栈帧 int MyAdd(int a, int b) {int c 0;c a b;return c; } int main() {int x 0xA;int y 0xB;int z MyAdd(x,y);system("pause");return …

怎么隐藏回收站?3个方法轻松隐藏回收站!

案例&#xff1a;怎么隐藏回收站 【我不太想把回收站放到桌面上&#xff0c;想把它隐藏了&#xff0c;请问大家有什么好的方法可以隐藏回收站吗&#xff1f;】 回收站是一个非常常见的功能&#xff0c;允许用户恢复已删除的文件。然而&#xff0c;有些人可能不希望回收站一直…

SpringMVC高手进阶

&#x1f648;作者简介&#xff1a;练习时长两年半的Java up主 &#x1f649;个人主页&#xff1a;程序员老茶 &#x1f64a; ps:点赞&#x1f44d;是免费的&#xff0c;却可以让写博客的作者开兴好久好久&#x1f60e; &#x1f4da;系列专栏&#xff1a;Java全栈&#xff0c;…

【MySQL】-- 数据库基础

目录 MySQL概述 MySQL初期概念 小结 主流数据库 连接服务器 服务器&#xff0c;数据库&#xff0c;表关系 数据逻辑存储 MySQL架构 SQL分类 存储引擎 存储引擎 查看存储引擎 MySQL概述 #问&#xff1a;什么是数据库&#xff1f; MySQL初期概念 这个所谓的mysql严格…

从零开始Vue3+Element Plus后台管理系统(七)——手写一个简单的多页签组件

以前都是用别人现成的多页签组件&#xff0c;自己也想尝试下做个Vue3的版本&#xff0c;目前还只有基本功能&#xff0c;慢慢完善。 主要思路 使用 Pinia 记录页签数据、处理操作初始状态没有页签数据&#xff0c;使用默认路由数据填充右击页签&#xff0c;显示更多关闭操作…

移动云与启明星辰联合发布移动云|星辰安全品牌

数字中国时代&#xff0c;企业数字化转型不断深化&#xff0c;云安全市场发展持续高增&#xff0c;其安全更需自主可控、全程可信。基于此&#xff0c;移动云和启明星辰共同打造移动云|星辰安全品牌&#xff0c;聚力协行共筑安全云的压舱石&#xff0c;携手共塑中国云安全产业发…

原神服务器服务端多人联机教程

原神服务器服务端多人联机教程 大家好&#xff0c;我是艾西在上一篇文章中我们说了win系统服务器怎么搭建原神服务端&#xff0c;在最后结尾时有带一嘴怎么改为多人联机但不是很详细。哪么这篇文章艾西会给小伙伴们说清楚原神服务端怎么改为多人联机&#xff0c;毕竟玩游戏肯定…

MySQL高级语句(一)

一、SQL高级语句 1、 SELECT 显示表格中一个或数个栏位的所有资料 语法&#xff1a;SELECT "字段" FROM "表名"; select * from test1; select name from test1; select name,sex from test1;2、DISTINCT 不显示重复的内容 语法&#xff1a;SELECT D…