La supervisión de la infraestructura informática es compleja, pero una herramienta como Checkmk la hace más fácil.
Muchas organizaciones han añadido tecnologías nativas de la nube a su pila tecnológica para mejorar el rendimiento de sus productos. Al mismo tiempo, a menudo siguen ejecutando sus propias redes e infraestructuras locales. Este cambio a infraestructuras híbridas debe abordarse en la supervisión debido al enorme número de métricas que se generan cada segundo para diversos componentes, como el sistema operativo, el almacenamiento, el servidor, los entornos de nube, etc. Todos ellos son importantes para garantizar que las aplicaciones funcionen al máximo rendimiento.
Estas métricas son una señal esencial para Equipos DevOps para conocer el estado de su infraestructura. Por eso las organizaciones necesitan una solución de monitorización que les ayude a identificar rápidamente los problemas en producción con métricas, visualizaciones y análisis. Checkmk es una de las herramientas de monitorización de infraestructuras más populares y útiles. En este artículo, te contaré por qué Checkmk merece su buena reputación y cómo puedes dar los primeros pasos con ella.
¿Qué es Checkmk?
Checkmk comprueba constantemente el funcionamiento de cualquier aspecto de los entornos informáticos modernos y es especialmente adecuado para infraestructuras híbridas. Por un lado, Checkmk es flexible y admite contenedores, activos en la nube y sistemas locales como conmutadores y servidores. Por otro lado, es realmente fácil empezar y gestionar su monitorización, porque Checkmk viene con alertas automáticas basadas en una gran cantidad de conocimientos de TI y otras características inteligentes que le ahorrarán mucho tiempo.
Si desea utilizar Checkmk de forma gratuita, tiene dos opciones: En primer lugar, puede optar por Checkmk Raw Edition, que es completamente de código abierto y de uso gratuito sin ninguna limitación. En segundo lugar, está la Edición de prueba de Checkmk Enterprise que tiene todas las funciones adicionales de las ediciones Checkmk Enterprise, pero después de 30 días el número de hosts se limitará a 25.
¿Cómo resuelve Checkmk el problema?
Checkmk puede supervisar aplicaciones, servidores, bases de datos, redes, contenedores, almacenamiento, etc. Proporciona una lista masiva de más de 2.000 plug-ins de monitorización. Con estos complementos. Checkmk puede ampliarse para supervisar tecnologías específicas de distintos proveedores disponibles en el mercado. Algunos plug-ins populares de Checkmk son para Docker, KubernetesCisco, Nginx, VMware, Linux, Windows, AWS, Dell. Con sus más de 2.000 plug-ins, Checkmk destaca como una solución de monitorización de infraestructuras muy prometedora disponible en la actualidad.
Además, para cualquier solución de monitorización, es crucial la rapidez y la corrección con que pueden leer las métricas y configurar alertas y notificaciones inteligentes. La solución de Checkmk cumple todos estos criterios. Con su función de detección automática, Checkmk puede identificar más de 90% de servicios y dispositivos. Ahora, la mayoría de las empresas requieren escalabilidad y automatización. Puede escalar la capacidad de supervisión de cien hosts a miles de hosts con facilidad en Checkmk y aprovechar sus agentes disponibles para la automatización.
Instalar Checkmk en un contenedor Docker
En este artículo, voy a instalar el Checkmk Raw Edition en un contenedor Docker en un servidor Linux que se ejecuta en Ubuntu 20.04. Desde Dockerhub, puedes descargar el archivo Contenedor Docker Checkmk. Hasta ahora ha recibido más de 5 millones de visitas, lo que demuestra la popularidad y el amplio uso de Checkmk.
Tome la imagen Docker con la última versión de Checkmk y ejecútela dentro de un contenedor utilizando el comando docker container run
.
docker container run -dit -p 8080:5000 --tmpfs /opt/omd/sites/cmk/tmp:uid=1000,gid=1000 -v monitoring:/omd/sites --name monitoring -v /etc/localtime:/etc/localtime:ro --restart always checkmk/check-mk-raw:2.0.0-latest
El nombre del contenedor será 'monitoring', el servidor web escuchará en el puerto 5000 y se abrirá en el puerto 8080 del nodo. El contenedor utilizará el sistema de archivos temporal y la zona horaria local.
geekflare@geekflare:~$ sudo docker container run -dit -p 8080:5000 --tmpfs /opt/omd/sites/cmk/tmp:uid=1000,gid=1000 -v/omd/sites --name monitoring -v/etc/localtime:/etc/localtime:ro --restart always checkmk/check-mk-raw:2.0.0-latest
Unable to find image 'checkmk/check-mk-raw:2.0.0-latest' locally
2.0.0-latest: Pulling from checkmk/check-mk-raw
33847f680f63: Pull complete
474905f2790b: Pull complete
1804f0e63047: Pull complete
f36fe6334464: Pull complete
03c68dfa69cf: Pull complete
b60cfdb78e96: Pull complete
Digest: sha256:7788fa2e31c7270be201d75285c13ccc7a74f67f991872ea63ba0cfa6708cac6
Status: Downloaded newer image for checkmk/check-mk-raw:2.0.0-latest
9729e323a840a08b0e758cfa9e6dbf76ba5dab4b2ecc4eea5174b8ee1a5cfbcf
Puede comprobar si la imagen Docker se ha descargado ejecutando el comando docker images
.
geekflare@geekflare:~$ sudo docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
bitnami/node-exporter latest ba0f519ca49b 34 hours ago 104MB
checkmk/check-mk-raw 2.0.0-latest 097319702432 13 days ago 1.03GB
hello-world latest feb5d9fea6a5 7 weeks ago 13.3kB
Ejecute el comando docker ps
para ver si el contenedor Checkmk se está ejecutando.
geekflare@geekflare:~$ sudo docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
9729e323a840 checkmk/check-mk-raw:2.0.0-latest "/docker-entrypoint.…" About a minute ago Up 59 seconds (health: starting) 6557/tcp, 0.0.0.0:8080->5000/tcp, :::8080->5000/tcp monitoring
3d3a95ed3c25 bitnami/node-exporter:latest "/opt/bitnami/node-e…" 25 hours ago Up 25 hours 9100/tcp node-exporter
Para obtener los datos de acceso a la interfaz web de Checkmk, imprima el registro del contenedor Checkmk.
geekflare@geekflare:~$ sudo docker container logs 9729e323a840
### CREATING SITE 'cmk'
Adding /opt/omd/sites/cmk/tmp to /etc/fstab.
Going to set TMPFS to off.
Temporary filesystem already mounted
Updating core configuration...
Generating configuration for core (type nagios)...Precompiling host checks...OK
OK
Executing post-create script "01_create-sample-config.py"...OK
Created new site cmk with version 2.0.0p15.cre.
The site can be started with omd start cmk.
The default web UI is available at http://9729e323a840/cmk/
The admin user for the web applications is cmkadmin with password: ClFxBPre
For command line administration of the site, log in with 'omd su cmk'.
After logging in, you can change the password for cmkadmin with 'htpasswd etc/htpasswd cmkadmin'.
### STARTING XINETD
[ ok ] Starting internet superserver: xinetd.
### STARTING SITE
Temporary filesystem already mounted
Starting mkeventd...OK
Starting rrdcached...OK
Starting npcd...OK
Starting nagios...OK
Starting apache...OK
Starting redis...OK
Initializing Crontab...OK
### STARTING CRON
### CONTAINER STARTED
El contenedor Docker Checkmk se ejecutará por defecto en https://localhost:8080/cmk/check_mk. La salida del comando anterior te dice que el nombre de usuario es cmkadmin y la contraseña, en mi caso la contraseña es ClFxBPre. Abra la dirección en un navegador web y utilice sus credenciales para iniciar sesión.
Una vez que te conectes, este es el 'Panel principal' que aparecerá. Está vacío porque aún no ha añadido ningún host.
Monitorización de Docker con Checkmk
Normalmente, se instala el agente Checkmk en la máquina que aloja los contenedores Docker y se utiliza el complemento Checkmk para Docker con el fin de supervisar todos los contenedores. Este complemento (mk_docker.py) utiliza la API Python de Docker para realizar un seguimiento de los contenedores Docker y obtener una visibilidad completa de su estado y rendimiento en tiempo real. Puedes leer más detalles sobre Monitorización de Docker con Checkmk en el sitio web de Checkmk.
Dado que en mi entorno Docker sólo hay un contenedor Docker en ejecución, mi contenedor Docker Checkmk, sólo utilizaré el agente Checkmk que se ejecuta en el contenedor Docker y no instalaré Checkmk en mi host Docker. El agente está preinstalado en el contenedor Checkmk, por lo tanto, sólo tengo que añadir mi contenedor Checkmk como host.
Obtengamos la dirección IP en la que se está ejecutando el servicio Docker utilizando ifconfig
en el terminal.
geekflare@geekflare:~$ ifconfig
docker0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 172.17.0.1 netmask 255.255.0.0 broadcast 172.17.255.255
inet6 fe80::42:59ff:fe8a:8ba8 prefixlen 64 scopeid 0x20<link>
ether 02:42:59:8a:8b:a8 txqueuelen 0 (Ethernet)
RX packets 5559 bytes 7230215 (7.2 MB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 4164 bytes 614703 (614.7 KB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
enp0s3: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 192.168.0.108 netmask 255.255.255.0 broadcast 192.168.0.255
inet6 fe80::144a:4682:35e7:bb2 prefixlen 64 scopeid 0x20<link>
ether 08:00:27:91:82:82 txqueuelen 1000 (Ethernet)
RX packets 699491 bytes 1044235622 (1.0 GB)
RX errors 0 dropped 7 overruns 0 frame 0
TX packets 101260 bytes 7555470 (7.5 MB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536
inet 127.0.0.1 netmask 255.0.0.0
inet6 ::1 prefixlen 128 scopeid 0x10<host>
loop txqueuelen 1000 (Local Loopback)
RX packets 20655 bytes 8446042 (8.4 MB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 20655 bytes 8446042 (8.4 MB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
veth44ba5ce: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet6 fe80::145f:1fff:fee9:a7b0 prefixlen 64 scopeid 0x20<link>
ether 16:5f:1f:e9:a7:b0 txqueuelen 0 (Ethernet)
RX packets 5559 bytes 7308041 (7.3 MB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 4173 bytes 616263 (616.2 KB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
vetha82ee43: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet6 fe80::585c:6fff:fe0a:a79b prefixlen 64 scopeid 0x20<link>
ether 5a:5c:6f:0a:a7:9b txqueuelen 0 (Ethernet)
RX packets 0 bytes 0 (0.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 92 bytes 9799 (9.7 KB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
En mi caso, el servicio Docker se ejecuta en 172.17.0.1
. El siguiente paso es añadir el servicio Docker como host en Checkmk para que pueda ser monitorizado.
- Vaya a Checkmk y haga clic en Configuración -> Hosts.
- Haz clic en "Añadir host".
- Ahora indique el nombre de host y la dirección IP y haga clic en "Guardar e ir a la configuración del servicio".
- Una vez hecho esto, Checkmk iniciará la detección de servicios automáticamente.
Desplácese hacia abajo para ver los servicios de monitorización que se ejecutan en el host Docker. Puedes ver que los servicios no están siendo monitorizados actualmente. Si quieres monitorizarlo todo, la solución más fácil es hacer clic en 'Fix all'. Si quieres configurar qué servicios deben ser monitorizados, también puedes hacerlo en detalle. Haga clic en + si desea supervisar un servicio.
Una vez seleccionados los servicios que desea supervisar, aparecerán en la pestaña "Servicios supervisados". Obtendrá todos los detalles del estado de cada servicio que esté supervisando. Si hace clic en ? ese servicio pasará a la lista de servicios indecisos. Si pulsa sobre el X el servicio pasará a la pestaña "Servicios desactivados".
He desactivado cuatro servicios, por lo que puedo verlos en la pestaña de servicios desactivados.
Cuando termine de añadir los servicios, deberá activar los cambios antes de que pasen a producción.
- Haga clic en el campo resaltado con el signo de exclamación amarillo (!) en la esquina superior derecha para ver los cambios pendientes.
- Haga clic en Activar en sitios seleccionados.
Ha supervisado correctamente los servicios Docker con Checkmk.
Conclusión
Esto es todo sobre Checkmk, una herramienta de monitorización de infraestructuras. Es una herramienta muy fácil de usar que debes probar para monitorizar tus entornos de producción. Recomiendo probar la Checkmk Edición Gratuita para iniciar la supervisión.