Zabbix está diseñado para monitorear el rendimiento del servidor, la disponibilidad de un servidor, los dispositivos de red y otros componentes de la red. Podemos realizar fácilmente un seguimiento del estado de cualquier aplicación, sistema y dispositivo de red usando esto.
En este artículo, explicaré cómo instalar Zabbix 3.4, una herramienta de monitoreo de código abierto en nuestro último servidor Ubuntu 18.04 y le mostraré cómo agregar servidores remotos para el monitoreo.
El núcleo de Zabbix está integrado con Java y C, pero viene con una interfaz frontend fácil de usar construida en PHP que facilita el seguimiento y la supervisión de los sistemas.
Requisitos previos
- Un servidor Ubuntu 18.04 recién instalado con privilegios de usuario root.
- Un servidor LAMP bien configurado.
Instalando el servidor LAMP
Antes de instalar el servidor Zabbix, debemos configurar correctamente un servidor LAMP. Primero, podemos instalar Apache y PHP junto con algunos de los módulos PHP requeridos usando este comando a continuación:
#apt update -y
#apt install apache2 libapache2-mod-php7.2 php7.2 php7.2-xml php7.2-bcmath php7.2-mbstring -y
Una vez que todos los componentes estén instalados, necesitamos instalar MariaDB. Zabbix usa MySQL, Oracle y PostgreSQL para almacenar sus datos. Aquí instalamos MariaDB para almacenar sus datos. La última versión de este software está disponible en nuestro repositorio predeterminado de Ubuntu 18.04. Por lo tanto, simplemente podemos ejecutar este comando para instalarlo.
#apt install mariadb-server -y
A continuación, podemos iniciar y permitir que todos los servicios se inicien en el momento del arranque:
#systemctl start apache2
#systemctl enable apache2
#systemctl start mysql
#systemctl enable mysql
Por lo tanto, hemos terminado con nuestro servidor LAMP. A continuación, podemos comenzar nuestra instalación de Zabbix.
Instalación y configuración del servidor Zabbix
Dependiendo de la plataforma de nuestro sistema operativo y los requisitos, debemos elegir/instalar el último repositorio compatible de Zabbix en nuestro servidor.
Paso 1:Descargue e instale el repositorio de Zabbix con MySQL
Podemos descargar e instalar el último repositorio Zabbix 3.4 para nuestro servidor Ubuntu 18.04 con los siguientes comandos:
# wget https://repo.zabbix.com/zabbix/3.4/ubuntu/pool/main/z/zabbix-release/zabbix-release_3.4-1+bionic_all.deb
# dpkg -i zabbix-release_3.4-1+bionic_all.deb
# apt update
Paso 2:Instale el servidor Zabbix, la interfaz y Zabbix-Agent
En segundo lugar, debemos instalar nuestro servidor Zabbix, Frontend y Zabbix Agent desde el repositorio de Zabbix que instalamos. Ejecute este comando para instalarlo como se muestra a continuación:
# apt install zabbix-server-mysql zabbix-frontend-php zabbix-agent
Paso 3:crear la base de datos inicial de Zabbix
Una vez que todos los componentes anteriores estén instalados, podemos crear una base de datos para nuestro usuario de Zabbix:
~# mysql -uroot -p
Enter password:
Welcome to the MariaDB monitor. Commands end with ; or \g.
Your MariaDB connection id is 41
Server version: 10.1.29-MariaDB-6 Ubuntu 18.04
Copyright (c) 2000, 2017, Oracle, MariaDB Corporation Ab and others.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
MariaDB [(none)]> CREATE DATABASE zabbix character set utf8 collate utf8_bin;
Query OK, 1 row affected (0.01 sec)
MariaDB [(none)]> grant all privileges on zabbix.* to zabbix@localhost identified by 'password';
Query OK, 0 rows affected (0.00 sec)
MariaDB [(none)]> quit
Ahora puede importar el esquema y los datos iniciales a nuestra base de datos Zabbix recién creada. Se le pedirá que ingrese su contraseña de usuario de base de datos durante el proceso de importación.
# zcat /usr/share/doc/zabbix-server-mysql*/create.sql.gz | mysql -uzabbix -p zabbix
Paso 4:Configuración de la base de datos para el servidor Zabbix
En esta etapa, debe actualizar correctamente la contraseña de la base de datos en el archivo de configuración de Zabbix en /etc/zabbix/zabbix_server.conf
como a continuación:
# grep -i DBpassword /etc/zabbix/zabbix_server.conf
# For SQLite3 path to database file must be provided. DBUser and DBPassword are ignored.
### Option: DBPassword
DBPassword=password
Debe descomentar la opción de contraseña de base de datos y proporcionarle la contraseña de usuario exacta de Zabbix DB según sea necesario.
Paso 5:Configuración de PHP para la interfaz de Zabbix
Necesitamos configurar el PHP y establecer la zona horaria adecuada para llevar a cabo la instalación de Zabbix Frontend sin problemas. En primer lugar, puede establecer la zona horaria adecuada en su archivo de configuración de PHP ubicado en /etc/php/7.2/apache2/php.ini
y modifíquelo de acuerdo con su zona horaria preferida. Lo actualicé de la siguiente manera:
# grep -i timezone /etc/php/7.2/apache2/php.ini
; Defines the default timezone used by the date functions
; http://php.net/date.timezone
date.timezone = Europe/Riga
A continuación, debemos actualizar el archivo de configuración de Zabbix en /etc/zabbix/apache.conf
con la misma zona horaria que la siguiente:
# grep timezone /etc/zabbix/apache.conf
php_value date.timezone Europe/Riga
Descomentaría el php_value para la zona horaria en la sección Módulo PHP 7 en el archivo de configuración mencionado y actualizaría con la zona horaria exacta como antes.
Paso 6:Inicie los procesos de servidor y agente de Zabbix
Finalmente, podemos iniciar y habilitar todos los servicios requeridos de Zabbix y Apache2 con los siguientes comandos:
# systemctl restart zabbix-server zabbix-agent apache2
# systemctl enable zabbix-server zabbix-agent apache2
¡Eso es todo! Ahora nuestro servidor Zabbix estará en funcionamiento. Puede comprobar que funciona accediendo a la URL>>>http://Server-IP/zabbix
Instalación/configuración de la interfaz de Zabbix
Una vez que tenemos nuestro servidor Zabbix en funcionamiento, podemos acceder a nuestra interfaz Zabbix recién instalada con la URL>> http://Server-IP or hostname/zabbix.
Esto abrirá el asistente de instalación de la interfaz. Para que sea completamente funcional, debemos completar el proceso de configuración de Zabbix Frontend.
Naveguemos a través de cada proceso de configuración uno por uno. Puede hacer clic en Next Step
para comprobar los requisitos previos. En esta etapa, debemos asegurarnos de que nuestro servidor cumpla con todos los requisitos previos de software que se enumeran a continuación. Puede hacer clic en Siguiente paso para continuar una vez que haya terminado.
En esta etapa, asegúrese de actualizar los detalles para conectarse a nuestra base de datos de Zabbix para garantizar una conexión de base de datos adecuada y continuar con la configuración del servidor de Zabbix, incluido el host y el puerto 10051 destinado a él.
Finalmente, podemos verificar una vez más todas las configuraciones realizadas en las etapas anteriores en el Resumen previo a la instalación y hacer clic en Next Step
para completar la instalación.
Si todo va bien, recibirá el mensaje anterior que indica una instalación exitosa de la interfaz de Zabbix. Ahora puede hacer clic en la pestaña Finalizar para salir del asistente de instalación.
Acceso al panel de control de Zabbix
¡Viva! nuestro Zabbix Frontend está listo. Puede acceder a él utilizando las credenciales de inicio de sesión predeterminadas de Zabbix con el nombre de usuario "Admin"
y contraseña "zabbix"
en la URL>>>http://Server-IP/zabbix.
Cambiar la contraseña de administrador
Una vez que haya iniciado sesión con éxito en el panel frontal de Zabbix con las credenciales de inicio de sesión de administrador predeterminadas, es obligatorio modificar las credenciales de administrador por razones de seguridad. Puede modificar su contraseña de administrador navegando por la ruta:Administration > Users > Admin > Password > Change Password
como en las capturas de pantalla a continuación:
Agregar un host de monitoreo
Dado que nuestro servidor Zabbix está listo para usar, podemos probar su funcionamiento agregando nuestro primer host objetivo de monitoreo, que es nuestro propio servidor Zabbix. Puede hacerlo navegando por la ruta:Configuration >> Hosts
como en las capturas de pantalla.
Como puede ver, nuestro estado de host está configurado en estado deshabilitado de forma predeterminada. Necesitamos hacer clic en el botón deshabilitado para habilitar el agente Zabbix en este servidor para monitorear el host. Como se ve en la captura de pantalla, el Status
está en enabled
y el servidor ahora está siendo monitoreado.
Solo espere unos minutos para que nuestro servidor Zabbix obtenga los datos de monitoreo del servidor y actualice los gráficos. Ahora puede ver los gráficos del host navegando por la ruta:Monitoring > Screens > Server Name
como en la instantánea.
Agregar un servidor remoto
En primer lugar, debemos instalar/habilitar Zabbix Agent en nuestro host remoto. El trabajo del agente Zabbix es recopilar datos como el uso de la CPU, la memoria, el disco y la interfaz de red de un dispositivo. El agente de Zabbix puede realizar comprobaciones tanto pasivas (sondeo) como activas (captura). Estas comprobaciones se pueden realizar a intervalos o en función de horarios específicos. Veamos cómo instalar/habilitar el agente Zabbix en un nodo Ubuntu 18.04.
Instalando el Agente Zabbix
Inicialmente, necesita SSH para nuestro nuevo servidor host y descargar el Repositorio Zabbix 3.4 para nuestra configuración de host Ubuntu 18.04 e instalar el Agente Zabbix desde allí.
#wget http://repo.zabbix.com/zabbix/3.4/ubuntu/pool/main/z/zabbix-release/zabbix-release_3.4-1+bionic_all.deb
#dpkg -i zabbix-release_3.4-1+bionic_all.deb
#apt install zabbix-agent
Configuración del agente Zabbix
Ahora, puede configurar nuestro Agente Zabbix para iniciar conexiones adecuadas con el servidor Zabbix. Usamos claves previamente compartidas (PSK) para asegurar la conexión entre el servidor y el agente. La configuración del agente Zabbix se encuentra en /etc/zabbix/zabbix_agentd.conf
.
Paso 1:generar la clave PSK y configurarla.
En primer lugar, necesitamos generar la clave PSK. Esto se puede obtener ejecutando el comando:
#sh -c "openssl rand -hex 32 > /etc/zabbix/zabbix_agentd.psk"
Puede guardar esta clave que se utilizará durante la configuración del Agente.
# cat /etc/zabbix/zabbix_agentd.psk
abb6a14eace79044b9f3bab0c6cd26d50b4cfb3dc6fe2ef815b96216073b333b
Paso 2:agregar el servidor Zabbix a la configuración del agente.
Ahora debe abrir el archivo de configuración del Agente Zabbix /etc/zabbix/zabbix_agentd.conf
y configurarlo para establecer una conexión segura entre los servidores. Primero, debe editar el número de línea '95' y '136' con la IP del servidor Zabbix como se muestra a continuación. Aquí 172.104.210.183 es la IP de mi servidor Zabbix.
# sed -n '95 p' /etc/zabbix/zabbix_agentd.conf
Server=172.104.210.183
A continuación, debemos editar la línea 136 con la información del servidor Zabbix.
# sed -n '136 p' /etc/zabbix/zabbix_agentd.conf
ServerActive=172.104.210.183
Paso 3:Configurar y habilitar la conexión segura de PSK
Para configurar una conexión segura entre los servidores, estamos habilitando la conexión TLS con soporte PSK. Necesitamos editar las siguientes líneas en la configuración del Agente Zabbix en consecuencia para que sea posible.
Modifique las siguientes líneas en /etc/zabbix/zabbix_agentd.conf desde:
# sed -n -e 324p -e 335p -e 385p -e 392p /etc/zabbix/zabbix_agentd.conf
# TLSConnect=unencrypted
# TLSAccept=unencrypted
# TLSPSKIdentity=
# TLSPSKFile=
TO:
# sed -n -e 324p -e 335p -e 385p -e 392p /etc/zabbix/zabbix_agentd.conf
TLSConnect=psk
TLSAccept=psk
TLSPSKIdentity=PKI 001
TLSPSKFile=/etc/zabbix/zabbix_agentd.psk
Definición de cada sección:
TLSConnect=psk
*// Esto habilita el soporte de clave precompartida //*TLSAccept=psk
*// Esto permite aceptar todas las conexiones entrantes usando soporte PSK//*TLSPSKIdentity=PKI 001
*// Se proporciona un nombre único para identificar la clave precompartida de su Agente//*TLSPSKFile=/etc/zabbix/zabbix_agentd.psk
*// Esto ayuda al agente Zabbix a identificar su archivo PSK creado. //*
Paso 4:Inicie el Agente Zabbix
Ahora puede guardar estos cambios e iniciar el agente Zabbix y configurarlo para que se inicie en el momento del arranque con estos comandos a continuación:
~# systemctl start zabbix-agent
# systemctl enable zabbix-agent
Synchronizing state of zabbix-agent.service with SysV service script with /lib/systemd/systemd-sysv-install.
Executing: /lib/systemd/systemd-sysv-install enable zabbix-agent
Nuestro agente Zabbix ahora está listo para enviar datos al servidor Zabbix. Pero para usarlo, tenemos que vincular este Agente desde la consola web del servidor Zabbix.
Paso 5:agregar nuestro nuevo host al servidor Zabbix
Hemos instalado/configurado con éxito Zabbix Agent en nuestro nuevo host. Ahora necesitamos registrar este nuevo nodo en nuestro servidor Zabbix a través de nuestra consola web. Puede iniciar sesión en la interfaz web de nuestro servidor Zabbix con la URL>>http://Zabbix_ServerIP/zabbix/
con las credenciales de inicio de sesión de administrador creadas. Ahora podemos navegar por la ruta:Configuration > Hosts > Create Host
Esto abrirá la página de configuración del host, donde puede agregar el nombre del HOST y los detalles de IP del nuevo host. Además, puedes elegir el grupo al que prefieres añadir este nuevo host. Puede crear un nuevo grupo como prefiera o puede agregarlo a los grupos preexistentes. Un host se puede incluir en varios grupos según nuestra preferencia. Aquí, estoy agregando nuestro nuevo nodo a los Linux Servers
predeterminados grupo.
Después de agregar nuestro host, podemos modificar su configuración seleccionando nuestro nodo agregado de la lista de Hosts. Elegí Plantilla predeterminada Template OS Linux
para mi nodo. Puede elegir cualquier plantilla que prefiera de las listas de plantillas.
A continuación, debemos navegar a la pestaña Cifrado. Como hemos decidido, debemos elegir PSK tanto para las Conexiones al host como para las Conexiones desde el host. Luego establezca PSK identity
a PSK 001
, que es el valor de TLSPSKIdentity
configuración que configuramos en el Agente Zabbix al principio. Luego establezca el valor PSK en la clave que generó para el agente Zabbix. Es el que está almacenado en el archivo /etc/zabbix/zabbix_agentd.psk
en la máquina del agente.
¡Eso es todo! Ahora verá su nuevo host con etiquetas verdes que indican que todo funciona bien y que la conexión está encriptada.
Para asegurarse de que todo funcione, incluso puede apagar su nuevo host y ver si Zabbix está alertando sobre el problema. En ese caso, informará un problema como se ve en la captura de pantalla.
Del mismo modo, puede agregar nuevos hosts a su servidor Zabbix instalando y configurando el Agente Zabbix allí y registrándolo en su servidor Zabbix. Espero que este artículo sea útil e informativo. Publique sus valiosas sugerencias y comentarios al respecto.