用springboot开发一个snmp采集程序,并最终生成拓扑图(三)

这里记录一些关于snmp采集的概念

snmp protocol

snmp一般是udp的,simple network manager protocol, 监听在161端口

手动运行形式

一般手动运行的形式是 snmpwalk -v 2c -c public IPADDR OID

你需要首先安装好snmpwalk

OID

OID, 这个相当于一个key,用来对应要采集的目标,返回的value一般就是我们需要的值

OID可以翻译成一些文字的东西, 比如 Sysdescr ... 如何翻译的?这里又有一个叫"mib"的东西,它看起来像是一个txt文件,里面记录了它的名称,描述等,

如何知道这个OID?

如果你在linux下,可以用 apt install mib-download 之类的命令安装好这些mib, 另外还有许多企业私有mib, 比如华为,h3c, 瑞捷,迪普。。。 买设备的时候可以找厂家,另外可以去厂家网站上找,幸运的话

一般采集什么样的指标

最普遍的 设备的状态相关信息, 还有最重要的网口信息 另外还可能会关注组网配置,比如 vlan, LINKAGG等

CPU,内存信息

一般有一个common的oid, 这个可以查下 1.3.6.1.2.1下

但是,不同品牌设备,甚至同一品牌不同型号设备,采集cpu , mem的方式可能都是不同的,这一点很讨厌

它们往往隐藏在 1.3.6.1.4.1下面

我研究过manageEngine, prometheus snmp_exporter, librenms, zabbix的模板或者代码,可以知道这里面是分得很细的,可以多看看librenms的代码,尽管是php的,还是很好懂的,何况还可以求助于当前的代码AI

网口相关

一般这个都是用标准的mib,不过也有一些小问题

32bit/64bit

ifInOctets/ifOutOctets和ifHCInOctets/ifHCOutOctets

原来这个协议中,只有32位的字段,但是后来发现这个不够用,所以又添加了一些64位字段,所以交换机采集时,你需要注意有的时候要用这个64位的字段代替32位的,否则会出现一些奇怪的现象

counter值要转速率(rate)

ifInOctets/ifOutOctets 代表网口进出流量,首先它们是一个counter值,即计数值,它只会一直增长,而我们最关心的其实是网口速率, 是一个统计后算差值再求平均的过程(速率)

在prometheus中,我们可以用rate/ irate来自动做这个事, 但是如果你的DB是别的, 比如用ES/mysql/pg... 你就需要自己算好了

snmpwalk与snmpget

采集的性能问题

bulk肯定会比单个get要快,但是并不是所有地方都需要用的

比如网口采集,可以用一个简单的walk,但是其实这其中大部分指标都不会变化,最关心的指标只是20个中的6个左右,全量采集是比较浪费交换机cpu的

LLDP

LLDP可以直接的提供网口关联设备的查询,结果分散在多处,组合起来会显示一份比较全的记录,用户一般都比较认可这个

三表合成进行网口-ip-mac关联

fwdtable, arpTable, interfacetabl 可以组合,进行一些初步的网口关联IP查询,在我没有弄清LLDP前,这个东西也能给出一些结果

先写到这,有一些遗漏后面再补上

相关推荐
JOEH6010 分钟前
🛡️ 微服务雪崩救星:Sentinel 限流熔断实战,3行代码搞定高可用!
后端·全栈
aiopencode26 分钟前
iOS手动代码混淆函数和变量名基本原理和注意事项教程
后端
程序员威哥30 分钟前
YOLOv8用ConvMixer结构:简化Backbone,速度+20%,mAP仅降0.9%
后端
开心猴爷34 分钟前
如何在苹果手机上面进行抓包?iOS代理抓包,数据流抓包
后端
程序员威哥36 分钟前
轻量型YOLO入门:在嵌入式设备上跑通目标检测(树莓派实战)
后端
程序员威哥43 分钟前
基于YOLOv7的目标检测实战:彻底解决新手常见的「训练不收敛」问题
后端
程序员威哥1 小时前
从数据集标注到模型评估:YOLO完整工作流实战(附避坑清单)
后端
明月_清风1 小时前
模仿 create-vite / create-vue 风格写一个现代脚手架
前端·后端
南囝coding1 小时前
CSS终于能做瀑布流了!三行代码搞定,告别JavaScript布局
前端·后端·面试
Calvad0s1 小时前
application.yml和bootstrap.yml这两个配置文件有什么区别?
后端