OpenNMS Installazione · 7 min read · Oct 10, 2025

Installa e Configura OpenNMS su Alma Linux 8

OpenNMS è una piattaforma di monitoraggio e gestione della rete gratuita e open-source scritta in Java. È auto-ospitata e sviluppata da una comunità di utenti, sviluppatori e dal gruppo OpenNMS. OpenNMS ti consente di monitorare tutto sulle tue reti locali e remote, inclusi prestazioni, monitoraggio del traffico, provisioning, monitoraggio dei servizi, gestione degli eventi, supporto per grafici e altro ancora. OpenNMS utilizza SNPM e JMX per raccogliere le informazioni degli host remoti.

Questo post ti mostrerà come installare OpenNMS con Nginx su Alma Linux 8.

Prerequisiti

  • Un server che esegue Alma Linux 8.
  • Un nome di dominio valido puntato all’IP del tuo server.
  • Una password di root configurata sul server.

Installa Java JDK

OpenNMS è un’applicazione basata su Java. Quindi, Java JDK deve essere installato sul tuo server. Puoi installarlo eseguendo il seguente comando:

dnf install java-11-openjdk -y

Una volta installato Java, puoi verificare l’installazione di Java utilizzando il comando sottostante:

java --version

Otterrai il seguente output:

openjdk 11.0.13 2021-10-19 LTS
OpenJDK Runtime Environment 18.9 (build 11.0.13+8-LTS)
OpenJDK 64-Bit Server VM 18.9 (build 11.0.13+8-LTS, mixed mode, sharing)

Installa OpenNMS su Alma Linux 8

Per impostazione predefinita, OpenNMS non è incluso nel repo predefinito di Alma Linux. Quindi, dovrai aggiungere il repo ufficiale di OpenNMS al tuo sistema.

Puoi aggiungere il repo di OpenNMS e la chiave GPG eseguendo il seguente comando:

dnf install https://yum.opennms.org/repofiles/opennms-repo-stable-rhel8.noarch.rpm  
rpm --import https://yum.opennms.org/OPENNMS-GPG-KEY

Successivamente, installa OpenNMS eseguendo il seguente comando:

dnf install opennms -y

Questo installerà anche il server PostgreSQL sul tuo server.

Successivamente, cambia la directory in OpenNMS e inizializza il database PostgreSQL con il seguente comando:

cd /opt/opennms  
postgresql-setup initdb

Infine, avvia e abilita il servizio PostgreSQL con il seguente comando:

systemctl start postgresql  
systemctl enable postgresql

Ora puoi controllare lo stato di PostgreSQL con il seguente comando:

systemctl status postgresql

Otterrai il seguente output:

? postgresql.service - PostgreSQL database server
   Loaded: loaded (/usr/lib/systemd/system/postgresql.service; disabled; vendor preset: disabled)
   Active: active (running) since Sat 2022-01-15 13:34:47 UTC; 5s ago
  Process: 7305 ExecStartPre=/usr/libexec/postgresql-check-db-dir postgresql (code=exited, status=0/SUCCESS)
 Main PID: 7307 (postmaster)
    Tasks: 8 (limit: 11411)
   Memory: 15.9M
   CGroup: /system.slice/postgresql.service
           ??7307 /usr/bin/postmaster -D /var/lib/pgsql/data
           ??7309 postgres: logger process   
           ??7311 postgres: checkpointer process   
           ??7312 postgres: writer process   
           ??7313 postgres: wal writer process   
           ??7314 postgres: autovacuum launcher process   
           ??7315 postgres: stats collector process   
           ??7316 postgres: bgworker: logical replication launcher   

Jan 15 13:34:47 almalinux8 systemd[1]: Starting PostgreSQL database server...
Jan 15 13:34:47 almalinux8 postmaster[7307]: 2022-01-15 13:34:47.618 UTC [7307] LOG:  listening on IPv6 address "::1", port 5432
Jan 15 13:34:47 almalinux8 postmaster[7307]: 2022-01-15 13:34:47.618 UTC [7307] LOG:  listening on IPv4 address "127.0.0.1", port 5432

Configura PostgreSQL per OpenNMS

Successivamente, dovrai creare un database e un utente per OpenNMS.

Prima, accedi a PostgreSQL con il seguente comando:

su - postgres -c "psql -U postgres"

Successivamente, cambia la password di Postgres con il seguente comando:

alter user postgres with password 'mypassword';

Successivamente, crea un database e un utente per OpenNMS con il seguente comando:

createuser -P opennms  
createdb -O opennms opennms

Successivamente, esci dalla shell di PostgreSQL con il seguente comando:

\q

Successivamente, modifica il file di configurazione di PostgreSQL con il seguente comando:

nano /var/lib/pgsql/data/pg_hba.conf

Trova le seguenti righe:

host    all             all             127.0.0.1/32            ident
host    all             all             ::1/128                 ident

E sostituiscile con le seguenti righe:

host           all            all           127.0.0.1/32           md5
host           all            all           ::1/128                   md5

Infine, ricarica il servizio PostgreSQL per applicare le modifiche di configurazione:

systemctl reload postgresql

Configura OpenNMS

Successivamente, dovrai modificare il file di configurazione della sorgente dati di OpenNMS e definire il tuo database:

nano /opt/opennms/etc/opennms-datasources.xml

Cambia le seguenti righe che corrispondono alle tue credenziali del database:




Salva e chiudi il file, quindi esegui il seguente comando per rilevare il percorso di Java:

/opt/opennms/bin/runjava -s

Otterrai il seguente output:

runjava: Looking for an appropriate JVM...
runjava: Checking for an appropriate JVM in JAVA_HOME...
runjava: Skipping... JAVA_HOME not set.
runjava: Checking JVM in the PATH: "/etc/alternatives/java"...
runjava: Did not find an appropriate JVM in the PATH: "/etc/alternatives/java"
runjava: Searching for a good JVM...
runjava: Found a good JVM in "/usr/lib/jvm/java-11-openjdk-11.0.13.0.8-4.el8_5.x86_64/bin/java".
runjava: Value of "/usr/lib/jvm/java-11-openjdk-11.0.13.0.8-4.el8_5.x86_64/bin/java" stored in configuration file.

Successivamente, esegui il seguente comando per inizializzare il database e rilevare le librerie di sistema:

/opt/opennms/bin/install -dis

Otterrai il seguente output:

- Running pre-execution phase
  Creating backup of /opt/opennms/etc/service-configuration.xml
    Zipping /opt/opennms/etc/service-configuration.xml
- Running execution phase
  Current configuration: 32 services.
  A service entry named 'OpenNMS:Name=PerspectivePoller' already exists.
  Final configuration: 32 services.
- Saving the execution state
- Running post-execution phase
  Removing backup /opt/opennms/etc/service-configuration.xml.zip

Finished in 0 seconds
Upgrade completed successfully!

Infine, avvia e abilita il servizio OpenNMS con il seguente comando:

systemctl start opennms  
systemctl enable opennms

Puoi controllare lo stato di OpenNMS con il seguente comando:

systemctl status opennms

Otterrai il seguente output:

? opennms.service - OpenNMS server
   Loaded: loaded (/usr/lib/systemd/system/opennms.service; disabled; vendor preset: disabled)
   Active: active (running) since Sat 2022-01-15 13:39:33 UTC; 6s ago
  Process: 8638 ExecStart=/etc/init.d/opennms -s start (code=exited, status=0/SUCCESS)
 Main PID: 9722 (java)
    Tasks: 36 (limit: 11411)
   Memory: 181.2M
   CGroup: /system.slice/opennms.service
           ??9721 bash /etc/init.d/opennms -s start
           ??9722 /usr/lib/jvm/java-11-openjdk-11.0.13.0.8-4.el8_5.x86_64/bin/java --add-modules=java.base,java.compiler,java.datatransfer,ja>

Jan 15 13:39:22 almalinux8 systemd[1]: Starting OpenNMS server...
Jan 15 13:39:32 almalinux8 systemd[1]: opennms.service: Can't open PID file /opt/opennms/logs/opennms.pid (yet?) after start: No such file or>
Jan 15 13:39:33 almalinux8 systemd[1]: opennms.service: Supervising process 9722 which is not our child. We'll most likely not notice when it>
Jan 15 13:39:33 almalinux8 systemd[1]: Started OpenNMS server.

A questo punto, OpenNMS è avviato e ascolta sulla porta 8980. Puoi controllarlo con il seguente comando:

ss -antpl | grep 8980

Otterrai il seguente output:

LISTEN 0      50                      *:8980             *:*    users:(("java",pid=9722,fd=1031))   

Una volta terminato, puoi procedere al passaggio successivo.

Configura Nginx come Reverse Proxy per OpenNMS

Successivamente, dovrai installare Nginx e configurarlo come reverse proxy per OpenNMS. Per farlo, installa il server Nginx con il seguente comando:

dnf install nginx -y

Una volta installato Nginx, crea un file di configurazione per l’host virtuale Nginx:

nano /etc/nginx/conf.d/opennms.conf

Aggiungi le seguenti righe:

upstream opennms {
  server 127.0.0.1:8980;
}

server {
    listen 80;
    server_name opennms.example.com;

    access_log /var/log/nginx/access.log;
    error_log /var/log/nginx/error.log;

    location / {
        proxy_pass http://opennms/;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
        proxy_set_header Host $http_host;

        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forward-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forward-Proto http;
        proxy_set_header X-Nginx-Proxy true;

        proxy_redirect off;
    }
}

Salva e chiudi il file, quindi verifica la configurazione di Nginx con il seguente comando:

ginx -t

Otterrai il seguente output:

ginx: the configuration file /etc/nginx/nginx.conf syntax is ok
ginx: configuration file /etc/nginx/nginx.conf test is successful

Successivamente, avvia e abilita il servizio Nginx per avviarsi all’avvio del sistema:

systemctl start nginx  
systemctl enable nginx

Ora puoi controllare lo stato di Nginx con il seguente comando:

systemctl status nginx

Otterrai il seguente output:

? nginx.service - The nginx HTTP and reverse proxy server
   Loaded: loaded (/usr/lib/systemd/system/nginx.service; disabled; vendor preset: disabled)
   Active: active (running) since Sat 2022-01-15 13:44:05 UTC; 6s ago
  Process: 13489 ExecStart=/usr/sbin/nginx (code=exited, status=0/SUCCESS)
  Process: 13488 ExecStartPre=/usr/sbin/nginx -t (code=exited, status=0/SUCCESS)
  Process: 13486 ExecStartPre=/usr/bin/rm -f /run/nginx.pid (code=exited, status=0/SUCCESS)
 Main PID: 13491 (nginx)
    Tasks: 2 (limit: 11411)
   Memory: 3.7M
   CGroup: /system.slice/nginx.service
           ??13491 nginx: master process /usr/sbin/nginx
           ??13492 nginx: worker process

Jan 15 13:44:05 almalinux8 systemd[1]: Starting The nginx HTTP and reverse proxy server...
Jan 15 13:44:05 almalinux8 nginx[13488]: nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
Jan 15 13:44:05 almalinux8 nginx[13488]: nginx: configuration file /etc/nginx/nginx.conf test is successful
Jan 15 13:44:05 almalinux8 systemd[1]: nginx.service: Failed to parse PID from file /run/nginx.pid: Invalid argument
Jan 15 13:44:05 almalinux8 systemd[1]: Started The nginx HTTP and reverse proxy server.

Configura Firewall

Successivamente, dovrai consentire la porta 80 attraverso il firewall. Puoi consentirlo eseguendo il seguente comando:

firebase-cmd --add-service=http --permanent

Successivamente, ricarica il firewall per applicare le modifiche:

firebase-cmd --reload

Una volta terminato, puoi procedere al passaggio successivo.

Accedi all’Interfaccia Web di OpenNMS

Ora, apri il tuo browser web e accedi all’interfaccia web di OpenNMS utilizzando l’URL http://opennms.example.com. Otterrai la schermata di accesso di OpenNMS:

Fornisci il nome utente e la password di admin predefiniti come admin/admin e fai clic sul pulsante Login. Otterrai il dashboard di OpenNMS nella schermata successiva:

Ora, fai clic su admin => Cambia Password per cambiare la password predefinita come mostrato di seguito:

Cambia la tua password predefinita e fai clic sul pulsante Submit. Otterrai la seguente schermata:

Conclusione

Congratulazioni! hai installato con successo OpenNMS con Nginx su Alma Linux 8. Ora puoi aggiungere gli host remoti dal dashboard di OpenNMS e iniziare a monitorarli da una posizione centrale. Sentiti libero di chiedermi se hai domande.

Share: X/Twitter LinkedIn

Ricevi i nuovi post nella tua casella di posta.

Nessuno spam. Disiscriviti in qualsiasi momento.