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 -y

Uma vez que o Java esteja instalado, você pode verificar a instalação do Java usando o comando abaixo:

java --version

Você 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-KEY

Em seguida, instale o OpenNMS executando o seguinte comando:

dnf install opennms -y

Isso 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 initdb

Finalmente, inicie e habilite o serviço PostgreSQL com o seguinte comando:

systemctl start postgresql  
systemctl enable postgresql

Agora você pode verificar o status do PostgreSQL com o seguinte comando:

systemctl status postgresql

Você 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 opennms

Em seguida, saia do shell do PostgreSQL com o seguinte comando:

\q

Em seguida, edite o arquivo de configuração do PostgreSQL com o seguinte comando:

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

Encontre 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 postgresql

Configurar 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.xml

Altere 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 -s

Você 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 -dis

Você 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 opennms

Você pode verificar o status do OpenNMS com o seguinte comando:

systemctl status opennms

Você 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 8980

Você 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 -y

Uma vez que o Nginx esteja instalado, crie um arquivo de configuração de host virtual do Nginx:

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

Adicione 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 -t

Você 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 nginx

Agora você pode verificar o status do Nginx com o seguinte comando:

systemctl status nginx

Você 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 --permanent

Em seguida, recarregue o firewall para aplicar as alterações:

firebase-cmd --reload

Uma 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.

Share: X/Twitter LinkedIn

Receba novas postagens na sua caixa de entrada

Sem spam. Cancele a assinatura a qualquer momento.