5 自动发现 SNMP OIDs (旧版)
概述
在本章节中,我们将对交换机执行一个SNMP 发现。
监控项键值
与文件系统和网络接口发现不同,监控项不一定必须具有 "snmp.discovery" 键值 - SNMP agent 类型的监控项就足够了。
要配置发现规则,请执行以下操作:
- 转到:数据采集 → 模板
- 在相应模板所在行中点击 发现

- 在屏幕右上角点击 创建发现规则
- 按如下截图所示,填写发现规则表单中的必填信息

所有必填输入字段都用红色星号标记。
要发现的 OID 在 SNMP OID 字段中按以下格式定义:discovery[{#MACRO1}, oid1, {#MACRO2}, oid2, …,]
其中 {#MACRO1}、{#MACRO2} 等是有效的 lld 宏名称,而 oid1、oid2 等是能够为这些宏生成有意义值的 OID。内置宏 {#SNMPINDEX}(包含已发现 OID 的索引)会应用于已发现实体。已发现实体按 {#SNMPINDEX} 宏值分组。
下面是一个在交换机上执行若干次 snmpwalk 的示例:
$ snmpwalk -v 2c -c public 192.168.1.1 IF-MIB::ifDescr
IF-MIB::ifDescr.1 = STRING: WAN
IF-MIB::ifDescr.2 = STRING: LAN1
IF-MIB::ifDescr.3 = STRING: LAN2
$ snmpwalk -v 2c -c public 192.168.1.1 IF-MIB::ifPhysAddress
IF-MIB::ifPhysAddress.1 = STRING: 8:0:27:90:7a:75
IF-MIB::ifPhysAddress.2 = STRING: 8:0:27:90:7a:76
IF-MIB::ifPhysAddress.3 = STRING: 8:0:27:2b:af:9e
并将 SNMP OID 设置为:
discovery[{#IFDESCR}, ifDescr, {#IFPHYSADDRESS}, ifPhysAddress]
现在,此规则将发现以下实体:{#IFDESCR} 宏设置为 WAN、LAN1 和 LAN2,{#IFPHYSADDRESS} 宏设置为 8:0:27:90:7a:75、8:0:27:90:7a:76 和 8:0:27:2b:af:9e,{#SNMPINDEX} 宏设置为已发现 OID 索引 1、2 和 3:
[
{
"{#SNMPINDEX}": "1",
"{#IFDESCR}": "WAN",
"{#IFPHYSADDRESS}": "8:0:27:90:7a:75"
},
{
"{#SNMPINDEX}": "2",
"{#IFDESCR}": "LAN1",
"{#IFPHYSADDRESS}": "8:0:27:90:7a:76"
},
{
"{#SNMPINDEX}": "3",
"{#IFDESCR}": "LAN2",
"{#IFPHYSADDRESS}": "8:0:27:2b:af:9e"
}
]
如果某个实体没有指定的 OID,则该实体将省略相应的宏。例如,如果我们有以下数据:
ifDescr.1 "Interface #1"
ifDescr.2 "Interface #2"
ifDescr.4 "Interface #4"
ifAlias.1 "eth0"
ifAlias.2 "eth1"
ifAlias.3 "eth2"
ifAlias.5 "eth4"
那么在这种情况下,SNMP 发现
discovery[{#IFDESCR}, ifDescr, {#IFALIAS}, ifAlias] 将返回以下结构:
[
{
"{#SNMPINDEX}": 1,
"{#IFDESCR}": "Interface #1",
"{#IFALIAS}": "eth0"
},
{
"{#SNMPINDEX}": 2,
"{#IFDESCR}": "Interface #2",
"{#IFALIAS}": "eth1"
},
{
"{#SNMPINDEX}": 3,
"{#IFALIAS}": "eth2"
},
{
"{#SNMPINDEX}": 4,
"{#IFDESCR}": "Interface #4"
},
{
"{#SNMPINDEX}": 5,
"{#IFALIAS}": "eth4"
}
]
监控项原型
以下截图说明了我们如何在监控项原型中使用这些宏:

您可以根据需要创建任意数量的监控项原型:

触发器原型
以下截图说明了我们如何在触发器原型中使用这些宏:


图形原型
以下截图说明了我们如何在图形原型中使用这些宏:


我们的发现规则摘要:

已发现的实体
当服务器运行时,它将根据 SNMP 发现规则返回的值创建实际的监控项、触发器和图形。在主机配置中,它们前面会带有一个橙色链接,指向其来源的发现规则。


