In this section we will perform an SNMP discovery on a switch.
This discovery method of SNMP OIDs has been supported since Zabbix server/proxy 6.4.
Create an SNMP item, using the following item key in the SNMP OID field:
This item will perform an snmpwalk for the OIDs specified in the parameters (1.3.6.1.2.1.2.2.1.2, 1.3.6.1.2.1.2.2.1.3), returning a concatenated list of values, e.g.:
.1.3.6.1.2.1.2.2.1.2.1 = STRING: "lo"
.1.3.6.1.2.1.2.2.1.2.2 = STRING: "ens33"
.1.3.6.1.2.1.2.2.1.2.3 = STRING: "ens37"
.1.3.6.1.2.1.2.2.1.3.1 = INTEGER: 24
.1.3.6.1.2.1.2.2.1.3.2 = INTEGER: 6
.1.3.6.1.2.1.2.2.1.3.3 = INTEGER: 6
Go to the discovery rules of your template/host. Click on Create discovery rule in the upper right corner of the screen.
Fill in the required details in the Discovery rule tab:
In the Preprocessing tab, select the SNMP walk to JSON preproccesing step.
In the field name specify a valid LLD macro name. Select the corresponding OID path to discover values from.
This rule will discover entities and set:
lo
, ens33
, and ens37
;24
, 6
, and 6
.A built-in macro {#SNMPINDEX} containing the index of the discovered OIDs is applied to discovered entities. The discovered entities are grouped by {#SNMPINDEX} macro value: 1, 2 and 3:
[
{
"{#SNMPINDEX}": "1",
"{#IFDESCR}": "lo",
"{#IFTYPE}": "24"
},
{
"{#SNMPINDEX}": "2",
"{#IFDESCR}": "ens33",
"{#IFTYPE}": "6"
},
{
"{#SNMPINDEX}": "3",
"{#IFDESCR}": "ens37",
"{#IFTYPE}": "6"
}
]
If an entity does not have the specified OID, then the corresponding macro will be omitted for this entity.
The following screenshot illustrates how we can use these macros in item prototypes:
Again, creating as many item prototypes as needed:
When server runs, it will create real items, triggers and graphs based on the values the SNMP discovery rule returns. In the host configuration they are prefixed with an orange link to a discovery rule they come from.