Anteriormente vimos cómo es que se instalaba TICK y Grafana, ahora vamos a ver como monitorizar dispositivos que brindad servicios de SNMP, el cual no es más que un protocolo ideado para la administración de dispositivos de red. No es objetivo del documento brindar toda una explicación acerca de cómo trabaja el protocolo, nos centraremos en como configurar nuestro agente Telegraf para que pueda realizar los pedidos por SNMP al dispositivo y enviar las respuestas a InfluxDB, para luego verlas en Grafana.
Me basaré en obtener la información de transferencia de datos que tiene nuestro router externo. Aunque a veces monitorizamos la transferencia de datos que sucede en nuestro Firewall de frontera (ya sea pfSense, OPNSense, Untangle, etc.), es mejor ver directamente desde el router cuantos paquetes se están transmitiendo. Además de que podemos obtener directamente el estado de la línea, estado del router, entre otros detalles brindados en la respuesta de SNMP.
Manos a la obra
Lo primero que hay que hacer es instalar Telegraf en el servidor que se encargará de realizar los pedidos SNMP al router, mientras más cerca del router mejor, en mi caso lo pongo en el Firewall de frontera con un PfSense (el cual trae telegraf en su repositorio de paquetes):
Para distribuciones basadas en Debian:
apt install telegraf
Para pfSense:
pkg install telegraf
Luego toca adicionar la configuración para el SNMP dentro de los ficheros de Telegraf, hay varias maneras, expondré la que uso que trata de respetar la configuración de los paquetes:
Distribuciones de Debian
En este caso Telegraf crea una carpeta /etc/telegraf/telegraf.d/ que todos los ficheros .conf que pongas serán extensiones a la configuración. Es preferible esta manera, puesto que alguna futura actualización del paquete que modificara el fichero principal de configuración /etc/telegraf/telegraf.conf no tendría que venir acompañados al típico error de dpkg al intentar instalar un nuevo fichero de configuración sobre uno modificado. Por tanto crearemos en esa carpeta un fichero llamado snmp.conf que contendrá la configuración que más adelante se expone para obtener los datos.
pfSense
Para este caso no existe la carpeta como en Debian, pero tampoco deberíamos modificar directamente el fichero de configuración que se encuentra en /usr/local/etc/telegraf.conf debido a que pfSense utiliza un sistema para las configuraciones con un XML que se representa en su administración web y es el que genera la configuración final, por lo que debemos modificar directamente el fichero «template» con PHP que se encuentra en /usr/local/pkg/telegraf.inc De esta manera cualquier reconfiguración o reiniciado del servicio mantendría nuestra configuración, no siendo así en el caso de una actualización de versión del paquete, por lo que deberían guardar las configuraciones adicionales.
Configuración de Telegraf
Para poder configurar el Telegraf deberíamos conocer un poco de cómo es que trabaja SNMP, sin dar grandes argumentos SNMP trabaja parecido a una Base de Datos de llave-valor, donde la llave es un OID (un identificador único para la métrica) y el valor correspondiente, además de que un valor puede ser a manera de tabla, es decir, incluir sub-llaves. Los OID se pueden especificar tanto numéricamente como por su nombre (lo cual es más cómodo) y su especificación podemos encontrarla en varios sitios, como OID-Info. En estos sitios puedes buscar el OID correspondiente a nuestro dispositivo y luego especificarle a Telegraf que obtenga el valor.
En nuestro ejemplo utilizaremos la OID específica a las interfaces de red, que es la IF-MIB (.1.3.6.1.2.1.2.) donde se encuentra todo lo relacionado con las interfaces del dispositivo. Pueden obtener más información aquí. Los que más uso de ahí son:
# Información de las entradas y salidas como enteros de 32 bit, con un link de 1 Gbps, en # 20 segundos a máxima velocidad llega al límite. IF-MIB::ifHCInOctets IF-MIB::ifHCOutOctets # Información de las entradas y salidas como enteros de 64 bit, routers relativamente nuevos, # preferido por el problema del anterior IF-MIB::ifHCInOctets IF-MIB::ifHCOutOctets # Información acerca del estado de la interfaz: # 1 -> OK # 2 -> Desconectada # 3 -> En pruebas # 4 -> Desconocido # etc. IF-MIB::ifOperStatus # Información de paquetes con errores IF-MIB::ifInErrors IF-MIB::ifOutErrors
Cada uno de ellos representa las métricas que comentaba. Pudieran incluso agregar el OID que representa el nivel de tinta en una impresora HP que soporte red (por ejemplo OID para HP LaserJet).
La otra parte interesante es saber a que interfaz es que queremos obtener las métricas (partiendo de mi método que quiero extraer solo los datos que necesito, no toda la tabla informativa). Para esta tarea nos ayudamos de snmpwalk del paquete snmp en Debian, con el cual se puede recorrer todo el arbol SNMP del dispositivo:
# Básico para un router con comunidad public y versión 2 de SNMP snmpwalk -m ALL -v 2c -c public 190.6.71.161
Eso te genera el árbol completo de OID del router, teniendo una salida parecida a:
... RFC1213-MIB::sysLocation.0 = STRING: "Beijing China" RFC1213-MIB::sysServices.0 = INTEGER: 78 RFC1213-MIB::ifNumber.0 = INTEGER: 10 RFC1213-MIB::ifIndex.128 = INTEGER: 128 RFC1213-MIB::ifIndex.262 = INTEGER: 262 RFC1213-MIB::ifIndex.518 = INTEGER: 518 RFC1213-MIB::ifIndex.642 = INTEGER: 642 RFC1213-MIB::ifIndex.770 = INTEGER: 770 RFC1213-MIB::ifIndex.898 = INTEGER: 898 RFC1213-MIB::ifIndex.1026 = INTEGER: 1026 RFC1213-MIB::ifIndex.1154 = INTEGER: 1154 RFC1213-MIB::ifIndex.1286 = INTEGER: 1286 RFC1213-MIB::ifIndex.1414 = INTEGER: 1414 RFC1213-MIB::ifDescr.128 = STRING: "InLoopBack0" RFC1213-MIB::ifDescr.262 = STRING: "NULL0" RFC1213-MIB::ifDescr.518 = STRING: "Aux0" RFC1213-MIB::ifDescr.642 = STRING: "Ethernet1/0" RFC1213-MIB::ifDescr.770 = STRING: "Ethernet1/1" RFC1213-MIB::ifDescr.898 = STRING: "Ethernet1/2" RFC1213-MIB::ifDescr.1026 = STRING: "Ethernet1/3" RFC1213-MIB::ifDescr.1154 = STRING: "Ethernet1/4" RFC1213-MIB::ifDescr.1286 = STRING: "Atm2/0" RFC1213-MIB::ifDescr.1414 = STRING: "Virtual-Ethernet2" RFC1213-MIB::ifType.128 = INTEGER: softwareLoopback(24) RFC1213-MIB::ifType.262 = INTEGER: other(1) RFC1213-MIB::ifType.518 = INTEGER: ppp(23) RFC1213-MIB::ifType.642 = INTEGER: ethernet-csmacd(6) RFC1213-MIB::ifType.770 = INTEGER: ethernet-csmacd(6) RFC1213-MIB::ifType.898 = INTEGER: ethernet-csmacd(6) RFC1213-MIB::ifType.1026 = INTEGER: ethernet-csmacd(6) RFC1213-MIB::ifType.1154 = INTEGER: ethernet-csmacd(6) RFC1213-MIB::ifType.1286 = INTEGER: 37 RFC1213-MIB::ifType.1414 = INTEGER: other(1) ...
En caso de que no salgan los nombres y te salgan solo los números OID, en debian podrías instalar el paquete snmp-mibs-downloader y ejecutar download-mibs como administrador para actualizar los MIBs que no son más que la definición de los OID en nombre y descripción.
En la salida anterior podemos ver como obtener el ID de la interfaz o interfaces que queremos monitorizar, en mi caso la 1286 que es de tipo ATM. Cada router puede dar esta información dependiente de marca, modelo, firmware, etc. les toca ir probando cuál es la que realmente quieren.
El plugin de SNMP de Telegraf permite la consulta completa de una tabla dentro de los SNMP, es decir que podríamos pedirle la consulta de todos los datos de todas las interfaces del router, por lo que no tendríamos que definir que interfaz monitorizar, pero en este caso solo requiero los datos de una en específico. Esto no es solo cuestión de minimizar datos, sino que los routers dedican gran parte de esfuerzo en generar la respuesta de SNMP, por lo que mientras menos datos pidamos, menos tardará el router en responder y menos carga le exigiremos.
Para el caso de querer obtener la tabla (a manera de ejemplo, pues no abarco sus gráficas en el grafana, aunque sería muy parecido) sería así:
[[inputs.snmp]] agents = [ "192.168.1.250:161" ] version = 2 community = "public" name = "snmp" # nombre que tendrá la métrica en InfluxDB [[inputs.snmp.field]] name = "hostname" oid = "RFC1213-MIB::sysName.0" is_tag = true [[inputs.snmp.table]] name = "snmp" inherit_tags = [ "hostname" ] oid = "IF-MIB::ifXTable" [[inputs.snmp.table.field]] name = "ifName" oid = "IF-MIB::ifName" is_tag = true
Ahora, continuando y configurando Telegraf para que obtenga solo los datos necesarios:
[[inputs.snmp]] agents = [ "10.10.10.10:161" ] version = 2 community = "public" name = "router_internet" interval = "10s" [[inputs.snmp.field]] name = "rx" oid = "IF-MIB::ifHCInOctets.1286" [[inputs.snmp.field]] name = "tx" oid = "IF-MIB::ifHCOutOctets.1286" [[inputs.snmp.field]] name = "status" oid = "IF-MIB::ifOperStatus.1286" [[inputs.snmp.field]] name = "erx" oid = "IF-MIB::ifInErrors.1286" [[inputs.snmp.field]] name = "etx" oid = "IF-MIB::ifOutErrors.1286" [[inputs.snmp.field]] name = "status" oid = "IF-MIB::ifOperStatus.1286"
Ahora en cuanto reiniciemos el Telegraf estará enviando los datos de las interfaces a nuestro Grafana y por tanto a configurarlo, mejor con una animación:
Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:70.0) Gecko/20100101 Firefox/70.0
socio como puedo configurar SNMP en opnsense
gracias por la ayuda antisipado
Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.142 Safari/537.36
Hola Luis Felipe, muy bien explicado tu post.
Gracias a este post entendí muchas cosas de grafana. Tengo una pregunta y ojalá puedas ayudarme.
En mi trabajo tengo instalado un server pfsense con telegraf instalado y en otro server con grafana, ya puedo ver uso el de disco, uso ram, tráfico total Wan y tráfico total de mi Lan. ¿Cómo puedo ver el tráfico de mis clientes (ip address) que pasan la interface Lan?
Gracias!!!