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

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

相关推荐
向上的车轮21 分钟前
无需云服务的家庭相册:OpenHarmony 上的 Rust 实践
开发语言·后端·rust
程序猿小蒜3 小时前
基于springboot的车辆管理系统设计与实现
java·数据库·spring boot·后端·spring·oracle
90后的晨仔3 小时前
Java后端开发:从零构建企业级应用的完整架构与技术栈详解
后端
我命由我123454 小时前
Spring Cloud - Spring Cloud 声明式接口调用(Fiegn 声明式接口调用概述、Fiegn 使用)
java·后端·spring·spring cloud·微服务·架构·java-ee
canonical_entropy4 小时前
领域驱动设计(DDD)中聚合根的最主要职责真的是维护一致性吗?
后端·架构·领域驱动设计
AntBlack4 小时前
不当韭菜 : 好像真有点效果 ,想藏起来自己用了
前端·后端·python
橙子家5 小时前
Serilog 日志库的简介
后端
间彧5 小时前
Java线程池深度实战:不同场景下的最优选择与性能优化
后端
间彧5 小时前
CompletableFuture与线程池:并发编程的双剑合璧
后端
间彧5 小时前
在实际项目中,如何根据任务类型(CPU/IO密集型)设计不同的线程池策略?
后端