Cómo instalar el software de monitoreo Nagios en Ubuntu 18.04 LTS

Compilar Nagios

Nagios es un software de código abierto para el monitoreo de sistemas y redes. Nagios puede monitorear la actividad de un host y sus servicios y proporciona una advertencia/alerta si sucede algo malo en el servidor. Nagios puede ejecutarse en sistemas operativos Linux y usaremos el servidor Ubuntu 18.04.

En este tutorial, le mostraremos paso a paso la instalación de Nagios 4.4.x en Ubuntu 18.04. Instalaremos Nagios Core 4.4.x desde la fuente, instalaremos los complementos nrpe y nagios, y luego agregaremos host para monitorear al servidor Nagios.

requisitos previos

  • 2 servidores Ubuntu 18.04
    • Servidor Nagios – nombre de host: hakase-nagios con una IP: 10.5.5.11
    • Cliente Ubuntu – nombre de host: client01 con una IP: 10.5.5.12
  • Privilegios de ra√≠z

Lo que haremos:

  • Instalar dependencias de paquetes
  • Instalar Nagios Core 4.4.5
  • Instale el complemento Nagios y el complemento NRPE
  • Agregar host a monitor al servidor Nagios
  • Pruebas

Paso 1: instalar las dependencias de los paquetes

Primero, actualizaremos el repositorio de Ubuntu e instalaremos algunas dependencias de paquetes para la instalación de Nagios.

Actualice el repositorio de Ubuntu usando el comando apt a continuación.

sudo apt update

Después de eso, instale las dependencias de los paquetes para la instalación de Nagios.

sudo apt install -y autoconf bc gawk dc build-essential gcc libc6 make wget unzip apache2 php libapache2-mod-php7.2 libgd-dev libmcrypt-dev make libssl-dev snmp libnet-snmp-perl gettext

Y ha instalado dependencias de paquetes para el servidor Nagios.

Paso 2: instale Nagios Core 4.4.5

En este paso, instalaremos la √ļltima versi√≥n estable de Nagios Core 4.4.5. Y lo instalaremos manualmente desde la fuente.

Descargar Nagios Core 4.4.5

Vaya a su directorio de inicio y descargue el código fuente de Nagios Core.

cd ~/
wget https://github.com/NagiosEnterprises/nagioscore/archive/nagios-4.4.5.tar.gz

Extraiga el paquete de Nagios y vaya al directorio de Nagios extraído.

tar xzf nagios-4.4.5.tar.gz
cd nagioscore-nagios-4.4.5/

Compilar e instalar Nagios

Primero, compile el código fuente de Nagios y defina la configuración de host virtual de Apache para Nagios.

sudo ./configure --with-httpd-conf=/etc/apache2/sites-enabled
sudo make all

Compilar Nagios

Cree el usuario y el grupo de Nagios y agregue el usuario de Apache ‘www-data’ al grupo ‘nagios’.

sudo make install-groups-users
sudo usermod -a -G nagios www-data

Instalar grupos y usuarios

Instale los binarios de Nagios, la secuencia de comandos del demonio de servicio y el modo de comando.

sudo make install
sudo make install-daemoninit
sudo make install-commandmode

Después de eso, instale la configuración del script de muestra.

sudo make install-config

Luego instale la configuración de Apache para Nagios y active los módulos mod_rewrite y mode_cgi.

sudo make install-webconf
sudo a2enmod rewrite cgi

Ahora reinicie el servicio de Apache.

systemctl restart apache2

Y ha instalado Nagios Core 4.4.5.

Instalar la configuración de Nagios

Crear usuario nagiosadmin

Después de instalar Nagios Core, agregaremos la autenticación básica para acceder al panel de control de Nagios. Y usaremos la autenticación básica de Apache.

Cree una nueva autenticaci√≥n b√°sica de apache para el usuario ¬ęnagiosadmin¬Ľ.

sudo htpasswd -c /usr/local/nagios/etc/htpasswd.users nagiosadmin

Escriba su contrase√Īa segura.

Establecer contrase√Īa para el administrador de NagiosAnuncio publicitario

Y ha creado un nuevo usuario ‘nagiosadmin’ para la autenticaci√≥n del panel de control de Nagios.

Configurar el cortafuegos UFW

Para la configuración del firewall, deberá agregar el servicio Apache y el puerto del servidor Nagios al firewall UFW.

Agregue el puerto Apache HTTP y el puerto Nagios ¬Ľ usando el comando ufw a continuaci√≥n.

sudo ufw allow Apache

Ahora recarga el firewall UFW.

sudo ufw reload

Y ha completado la instalación de Nagios Core en el servidor Ubuntu 18.04.

Configurar el cortafuegos UFW

Paso 3: instale los complementos de Nagios y el complemento NRPE

Después de instalar Nagios Core, instalaremos los complementos de Nagios y los complementos de NRPE.

Tanto los complementos de Nagios como los de NRPE están disponibles de forma predeterminada en el repositorio de Ubuntu. Puede instalar esos paquetes usando el comando apt a continuación.

sudo apt install nagios-plugins nagios-nrpe-plugin

Una vez completada la instalaci√≥n, vaya al directorio de instalaci√≥n de nagios ¬ę/usr/local/nagios¬Ľ y edite el archivo de configuraci√≥n ¬ęnagios.cfg¬Ľ.

cd /usr/local/nagios/
vim nagios.cfg

Descomente el directorio de configuración adicional para servidores.

cfg_dir=/usr/local/nagios/etc/servers

Guardar y cerrar.

Ahora cree un nuevo directorio ¬ę/usr/local/nagios/etc/servers¬Ľ que se usar√° para almacenar la configuraci√≥n del monitor de host.

mkdir -p /usr/local/nagios/etc/servers

Despu√©s de eso, vaya al directorio ¬ę/usr/local/nagios/etc/¬Ľ y edite el archivo de configuraci√≥n ¬ęresurces.cfg¬Ľ.

cd /usr/local/nagios/etc/
vim resources.cfg

Cambie el directorio predeterminado para los complementos de Nagios como se muestra a continuación.

$USER1$=/usr/lib/nagios/plugins

Guardar y cerrar.

A continuaci√≥n, agregue los contactos de administraci√≥n de Nagios editando el archivo de configuraci√≥n ¬ęobjects/contacts.cfg¬Ľ.

vim objects/contacts.cfg

Cambia la dirección de correo electrónico por la tuya.

define contact{
        ......
        email             [email protected]
}

Guardar y cerrar.

A continuaci√≥n, defina el comando de verificaci√≥n nrpe editando el archivo de configuraci√≥n ¬ęobjects/commands.cfg¬Ľ.

vim objects/commands.cfg

Pegue la siguiente configuración al final de la línea.

define command{
        command_name check_nrpe
        command_line $USER1$/check_nrpe -H $HOSTADDRESS$ -c $ARG1$
}

Guardar y cerrar.

Ahora inicie el servicio Nagios y agréguelo al arranque del sistema.

systemctl start nagios
systemctl enable nagios

Configure nagios, luego reinícielo para aplicar los cambios

El servicio de Nagios está en funcionamiento, compruébelo con el siguiente comando.

systemctl status nagios

A continuación se muestra el resultado.

Comprobar el estado de nagios

A continuación, debemos reiniciar el servicio de Apache para aplicar una nueva configuración de Nagios.

systemctl restart apache2

Despu√©s de eso, abra su navegador web y escriba la direcci√≥n IP del servidor siguiendo la ruta URL de ¬ęnagios¬Ľ.

http://10.5.5.11/nagios/

Inicie sesi√≥n con el usuario ¬ęnagiosadmin¬Ľ y escriba su contrase√Īa.

Iniciar sesión

Y obtendrá el Panel de Nagios como se muestra a continuación.

Tablero de instrumentos de Nagios

Como resultado, instaló Nagios en el servidor Ubuntu 18.04. Y puede agregar hosts al servidor Nagios.

Paso 5: agregue el host Linux al monitor

En este paso, agregaremos el servidor Ubuntu con el nombre de host ¬ęclient01¬Ľ y la direcci√≥n IP ¬ę10.5.5.12¬Ľ al servidor Nagios.

Instale el servidor NRPE en el servidor Client01

Inicie sesi√≥n en el servidor ¬ęclient01¬Ľ usando su ssh.

ssh [email protected]

Una vez que haya iniciado sesión, actualice el repositorio de Ubuntu e instale los complementos de Nagios y el servidor NRPE.

sudo apt update
sudo apt install nagios-nrpe-server nagios-plugins

A continuaci√≥n, vaya al directorio de instalaci√≥n de NRPE ¬ę/etc/nagios¬Ľ y edite el archivo de configuraci√≥n ¬ęnrpe.cfg¬Ľ.

cd /etc/nagios/
vim nrpe.cfg

Descomente la l√≠nea ¬ęserver_address¬Ľ y cambie el valor con la direcci√≥n IP ¬ęclient01¬Ľ.

server_address=10.5.5.12

En la l√≠nea ¬ęallowed_hosts¬Ľ, agregue la direcci√≥n IP del servidor Nagios ¬ę10.5.5.11¬Ľ.

allowed_hosts=127.0.0.1,::1,10.5.5.11

Guardar y cerrar.

A continuaci√≥n, edite la configuraci√≥n ¬ęnrpe_local.cfg¬Ľ.

vim nrpe_local.cfg

Cambie la direcci√≥n IP con la direcci√≥n IP ¬ęclient01¬Ľ y pegue la configuraci√≥n en ella.

command[check_root]=/usr/lib/nagios/plugins/check_disk -w 20% -c 10% -p /
command[check_ping]=/usr/lib/nagios/plugins/check_ping -H 10.5.5.12 -w 100.0,20% -c 500.0,60% -p 5
command[check_ssh]=/usr/lib/nagios/plugins/check_ssh -4 10.5.5.12
command[check_http]=/usr/lib/nagios/plugins/check_http -I 10.5.5.12
command[check_apt]=/usr/lib/nagios/plugins/check_apt

Guardar y cerrar.

Ahora reinicie el servicio NRPE y agréguelo al arranque del sistema.

systemctl restart nagios-nrpe-server
systemctl enable nagios-nrpe-server

Y el servidor Nagios NRPE est√° en funcionamiento.

Instalar NRPE

Verifique el servicio NRPE usando el siguiente comando.

systemctl status nagios-nrpe-server

El servicio NRPE est√° en funcionamiento.

El servidor NRPE está activo y en ejecución

Luego, regrese al servidor Nagios y verifique el servidor NRPE ¬ęclient01¬Ľ.

/usr/lib/nagios/plugins/check_nrpe -H 10.5.5.12
/usr/lib/nagios/plugins/check_nrpe -H 10.5.5.12 -c check_ping

Y obtendr√° el resultado de la siguiente manera.

Consultar NRPE

Y ha instalado el servidor Nagios NRPE y los complementos de Nagios en el host ¬ęclient01¬Ľ.

Agregar configuración de hosts al servidor Nagios

Vuelva a la terminal del servidor Nagios, vaya al directorio ¬ę/usr/local/nagios/etc¬Ľ y cree una nueva configuraci√≥n ¬ęserver/client01.cfg¬Ľ.

cd /usr/local/nagios/etc
vim servers/client01.cfg

Cambie la dirección IP y el nombre de host por los suyos y pegue la configuración en él.

# Ubuntu Host configuration file1

define host {
use                          linux-server
host_name                    client01
alias                        Ubuntu Host
address                      10.5.5.12
register                     1
}

define service {
host_name                       client01
service_description             PING
check_command                   check_nrpe!check_ping
max_check_attempts              2
check_interval                  2
retry_interval                  2
check_period¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬† 24×7
check_freshness                 1
contact_groups                  admins
notification_interval           2
notification_period¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬† 24×7
notifications_enabled           1
register                        1
}

define service {
host_name                       client01
service_description             Check Users
check_command                   check_nrpe!check_users
max_check_attempts              2
check_interval                  2
retry_interval                  2
check_period¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬† 24×7
check_freshness                 1
contact_groups                  admins
notification_interval           2
notification_period¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬† 24×7
notifications_enabled           1
register                        1
}

define service {
host_name                       client01
service_description             Check SSH
check_command                   check_nrpe!check_ssh
max_check_attempts              2
check_interval                  2
retry_interval                  2
check_period¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬† 24×7
check_freshness                 1
contact_groups                  admins
notification_interval           2
notification_period¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬† 24×7
notifications_enabled           1
register                        1
}

define service {
host_name                       client01
service_description             Check Root / Disk
check_command                   check_nrpe!check_root
max_check_attempts              2
check_interval                  2
retry_interval                  2
check_period¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬† 24×7
check_freshness                 1
contact_groups                  admins
notification_interval           2
notification_period¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬† 24×7
notifications_enabled           1
register                        1
}

define service {
host_name                       client01
service_description             Check APT Update
check_command                   check_nrpe!check_apt
max_check_attempts              2
check_interval                  2
retry_interval                  2
check_period¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬† 24×7
check_freshness                 1
contact_groups                  admins
notification_interval           2
notification_period¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬† 24×7
notifications_enabled           1
register                        1
}

define service {
host_name                       client01
service_description             Check HTTP
check_command                   check_nrpe!check_http
max_check_attempts              2
check_interval                  2
retry_interval                  2
check_period¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬† 24×7
check_freshness                 1
contact_groups                  admins
notification_interval           2
notification_period¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬†¬† 24×7
notifications_enabled           1
register                        1
}


Guardar y cerrar.

Ahora reinicie el servidor Nagios.

systemctl restart nagios

Configurar el cliente de Nagios

Paso 5 – Prueba

Vuelva a su navegador y espere unos minutos.

Haga clic en el ¬ęHospedadores¬Ľ men√ļ y obtendr√° el ¬ęcliente01¬Ľ se ha agregado.

Probando Nagios

A continuaci√≥n se muestran los detalles de la supervisi√≥n del servidor ¬ęclient01¬Ľ.

Otra prueba de Nagios

Ahora ha agregado Host para monitorear al servidor Nagios.

Y la instalación de Nagios 4.4.5 en Ubuntu 18.04 Server se completó con éxito.

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *