用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前,这个东西也能给出一些结果

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

相关推荐
一灯架构5 小时前
90%的人答错!一文带你彻底搞懂ArrayList
java·后端
mldong7 小时前
Python开发者狂喜!200+课时FastAPI全栈实战合集,10大模块持续更新中🔥
后端
GreenTea7 小时前
从 Claw-Code 看 AI 驱动的大型项目开发:2 人 + 10 个自治 Agent 如何产出 48K 行 Rust 代码
前端·人工智能·后端
Moment10 小时前
AI 全栈指南:NestJs 中的 Service Provider 和 Module
前端·后端·面试
IT_陈寒10 小时前
为什么我的JavaScript异步回调总是乱序执行?
前端·人工智能·后端
Moment10 小时前
AI全栈入门指南:NestJs 中的 DTO 和数据校验
前端·后端·面试
小村儿10 小时前
Harness Engineering:为什么你用 AI 越用越累?
前端·后端·ai编程
小码哥_常10 小时前
为什么PUT和DELETE请求在大公司中逐渐被弃用?
后端
宫_商_角_徵11 小时前
动态代理到底在做什么?
后端
苍何11 小时前
我把微信 cli 开源了,群消息终于不用爬楼了!
后端