OpenNMS · 7 min read · Oct 10, 2025
Instalar e Configurar OpenNMS no Alma Linux 8

OpenNMS é uma plataforma de monitoramento e gerenciamento de rede gratuita e de código aberto escrita em Java. É auto-hospedada e desenvolvida por uma comunidade de usuários, desenvolvedores e pelo OpenNMS Group. O OpenNMS permite monitorar tudo em suas redes locais e remotas, incluindo desempenho, monitoramento de tráfego, provisionamento, monitoramento de serviços, gerenciamento de eventos, suporte a gráficos e muito mais. O OpenNMS utiliza SNPM e JMX para coletar informações de hosts remotos.
Este post mostrará como instalar o OpenNMS com Nginx no Alma Linux 8.
Pré-requisitos
- Um servidor rodando Alma Linux 8.
- Um nome de domínio válido apontado para o IP do seu servidor.
- Uma senha de root configurada no servidor.
Instalar Java JDK
O OpenNMS é uma aplicação baseada em Java. Portanto, o Java JDK deve ser instalado em seu servidor. Você pode instalá-lo executando o seguinte comando:
dnf install java-11-openjdk -yUma vez que o Java esteja instalado, você pode verificar a instalação do Java usando o comando abaixo:
java --versionVocê receberá a seguinte saída:
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)
Instalar OpenNMS no Alma Linux 8
Por padrão, o OpenNMS não está incluído no repositório padrão do Alma Linux. Portanto, você precisará adicionar o repositório oficial do OpenNMS ao seu sistema.
Você pode adicionar o repositório do OpenNMS e a chave GPG executando o seguinte comando:
dnf install https://yum.opennms.org/repofiles/opennms-repo-stable-rhel8.noarch.rpm
rpm --import https://yum.opennms.org/OPENNMS-GPG-KEYEm seguida, instale o OpenNMS executando o seguinte comando:
dnf install opennms -yIsso também instalará o servidor PostgreSQL em seu servidor.
Em seguida, mude o diretório para o OpenNMS e inicialize o banco de dados PostgreSQL com o seguinte comando:
cd /opt/opennms
postgresql-setup initdbFinalmente, inicie e habilite o serviço PostgreSQL com o seguinte comando:
systemctl start postgresql
systemctl enable postgresqlAgora você pode verificar o status do PostgreSQL com o seguinte comando:
systemctl status postgresqlVocê receberá a seguinte saída:
? 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
Configurar PostgreSQL para OpenNMS
Em seguida, você precisará criar um banco de dados e um usuário para o OpenNMS.
Primeiro, faça login no PostgreSQL com o seguinte comando:
su - postgres -c "psql -U postgres"Em seguida, altere a senha do Postgres com o seguinte comando:
alter user postgres with password 'mypassword';Em seguida, crie um banco de dados e um usuário para o OpenNMS com o seguinte comando:
createuser -P opennms
createdb -O opennms opennmsEm seguida, saia do shell do PostgreSQL com o seguinte comando:
\qEm seguida, edite o arquivo de configuração do PostgreSQL com o seguinte comando:
nano /var/lib/pgsql/data/pg_hba.confEncontre as seguintes linhas:
host all all 127.0.0.1/32 ident
host all all ::1/128 ident
E substitua-as pelas seguintes linhas:
host all all 127.0.0.1/32 md5
host all all ::1/128 md5
Finalmente, recarregue o serviço PostgreSQL para aplicar as alterações de configuração:
systemctl reload postgresqlConfigurar OpenNMS
Em seguida, você precisará editar o arquivo de configuração da fonte de dados do OpenNMS e definir seu banco de dados:
nano /opt/opennms/etc/opennms-datasources.xmlAltere as seguintes linhas que correspondem às suas credenciais de banco de dados:
Salve e feche o arquivo e, em seguida, execute o seguinte comando para detectar o caminho do Java:
/opt/opennms/bin/runjava -sVocê receberá a seguinte saída:
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.
Em seguida, execute o seguinte comando para inicializar o banco de dados e detectar bibliotecas do sistema:
/opt/opennms/bin/install -disVocê receberá a seguinte saída:
- 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!
Finalmente, inicie e habilite o serviço OpenNMS com o seguinte comando:
systemctl start opennms
systemctl enable opennmsVocê pode verificar o status do OpenNMS com o seguinte comando:
systemctl status opennmsVocê receberá a seguinte saída:
? 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.
Neste ponto, o OpenNMS está iniciado e escutando na porta 8980. Você pode verificar isso com o seguinte comando:
ss -antpl | grep 8980Você receberá a seguinte saída:
LISTEN 0 50 *:8980 *:* users:(("java",pid=9722,fd=1031))
Uma vez que você tenha terminado, pode prosseguir para a próxima etapa.
Configurar Nginx como um Proxy Reverso para OpenNMS
Em seguida, você precisará instalar o Nginx e configurá-lo como um proxy reverso para o OpenNMS. Para fazer isso, instale o servidor Nginx com o seguinte comando:
dnf install nginx -yUma vez que o Nginx esteja instalado, crie um arquivo de configuração de host virtual do Nginx:
nano /etc/nginx/conf.d/opennms.confAdicione as seguintes linhas:
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;
}
}
Salve e feche o arquivo e, em seguida, verifique a configuração do Nginx com o seguinte comando:
ginx -tVocê receberá a seguinte saída:
ginx: the configuration file /etc/nginx/nginx.conf syntax is ok
ginx: configuration file /etc/nginx/nginx.conf test is successful
Em seguida, inicie e habilite o serviço Nginx para iniciar na inicialização do sistema:
systemctl start nginx
systemctl enable nginxAgora você pode verificar o status do Nginx com o seguinte comando:
systemctl status nginxVocê receberá a seguinte saída:
? 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.
Configurar Firewall
Em seguida, você precisará permitir a porta 80 através do firewall. Você pode permitir isso executando o seguinte comando:
firebase-cmd --add-service=http --permanentEm seguida, recarregue o firewall para aplicar as alterações:
firebase-cmd --reloadUma vez que você tenha terminado, pode prosseguir para a próxima etapa.
Acessar a Interface Web do OpenNMS
Agora, abra seu navegador e acesse a interface web do OpenNMS usando a URL http://opennms.example.com. Você verá a tela de login do OpenNMS:

Forneça o nome de usuário e a senha padrão como admin/admin e clique no botão Login. Você verá o painel do OpenNMS na tela seguinte:

Agora, clique no botão admin => Alterar Senha para alterar a senha padrão, conforme mostrado abaixo:

Altere sua senha padrão e clique no botão Enviar. Você verá a seguinte tela:

Conclusão
Parabéns! você instalou com sucesso o OpenNMS com Nginx no Alma Linux 8. Agora você pode adicionar os hosts remotos a partir do painel do OpenNMS e começar a monitorá-los a partir de um local central. Sinta-se à vontade para me perguntar se você tiver alguma dúvida.
Receba novas postagens na sua caixa de entrada
Sem spam. Cancele a assinatura a qualquer momento.