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 -yUna volta installato Java, puoi verificare l’installazione di Java utilizzando il comando sottostante:
java --versionOtterrai 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-KEYSuccessivamente, installa OpenNMS eseguendo il seguente comando:
dnf install opennms -yQuesto 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 initdbInfine, avvia e abilita il servizio PostgreSQL con il seguente comando:
systemctl start postgresql
systemctl enable postgresqlOra puoi controllare lo stato di PostgreSQL con il seguente comando:
systemctl status postgresqlOtterrai 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 opennmsSuccessivamente, esci dalla shell di PostgreSQL con il seguente comando:
\qSuccessivamente, modifica il file di configurazione di PostgreSQL con il seguente comando:
nano /var/lib/pgsql/data/pg_hba.confTrova 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 postgresqlConfigura OpenNMS
Successivamente, dovrai modificare il file di configurazione della sorgente dati di OpenNMS e definire il tuo database:
nano /opt/opennms/etc/opennms-datasources.xmlCambia 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 -sOtterrai 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 -disOtterrai 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 opennmsPuoi controllare lo stato di OpenNMS con il seguente comando:
systemctl status opennmsOtterrai 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 8980Otterrai 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 -yUna volta installato Nginx, crea un file di configurazione per l’host virtuale Nginx:
nano /etc/nginx/conf.d/opennms.confAggiungi 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 -tOtterrai 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 nginxOra puoi controllare lo stato di Nginx con il seguente comando:
systemctl status nginxOtterrai 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 --permanentSuccessivamente, ricarica il firewall per applicare le modifiche:
firebase-cmd --reloadUna 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.
Ricevi i nuovi post nella tua casella di posta.
Nessuno spam. Disiscriviti in qualsiasi momento.