Monitore seus dispositivos usando o LibreNMS no Ubuntu 16.04

O LibreNMS é um sistema de monitoramento de rede de código aberto completo. Ele usa SNMP para obter os dados de diferentes dispositivos. Uma variedade de dispositivos é suportada no LibreNMS, como Cisco, Linux, FreeBSD, Juniper, Brocade, Foundry, HP e muitos mais. Ele suporta múltiplos mecanismos de autenticação e autenticação de dois fatores. Possui um sistema de alerta personalizável que pode alertar o administrador da rede por email, IRC ou folga.

Pré-requisitos

  • Uma instância do servidor Vultr Ubuntu 16.04.
  • Um usuário sudo .

Neste tutorial, usaremos nms.example.com como o nome de domínio apontado para a instância do Vultr. Certifique-se de substituir todas as ocorrências do nome de domínio de exemplo pelo nome real.

Atualize seu sistema base usando o guia Como atualizar o Ubuntu 16.04 . Depois que seu sistema for atualizado, continue com a instalação das dependências.

Instale Nginx e PHP

O front end do LibreNMS é escrito em PHP, portanto, precisamos instalar um servidor da Web e PHP. Neste tutorial, instalaremos o Nginx junto com o PHP 7.2 para obter o máximo de segurança e desempenho.

Instale o Nginx.

sudo apt -y install nginx

Inicie o Nginx e permita que ele inicie automaticamente na inicialização.

sudo systemctl start nginx
sudo systemctl enable nginx

Adicione e ative o repositório Remi, pois o repositório apt padrão contém uma versão mais antiga do PHP.

sudo add-apt-repository --yes ppa:ondrej/php
sudo apt update

Instale o PHP versão 7.2 junto com os módulos exigidos pelo LibreNMS.

sudo apt -y install php7.2 php7.2-cli php7.2-common php7.2-curl php7.2-fpm php7.2-gd php7.2-mysql php7.2-snmp php7.2-mbstring php7.2-xml php7.2-zip zip unzip

Abra o arquivo de configuração carregado em um editor.

sudo nano /etc/php/7.2/fpm/php.ini

Encontre as seguintes linhas.

;cgi.fix_pathinfo=1
;date.timezone =

Remova o comentário e use esses valores; substitua Asia/Kolkata pelo fuso horário local.

cgi.fix_pathinfo=0
date.timezone = Asia/Kolkata

Você também precisará alterar o fuso horário do sistema executando o seguinte comando.

sudo ln -sf /usr/share/zoneinfo/Asia/Kolkata /etc/localtime

Reinicie o PHP-FPM.

sudo systemctl restart php7.2-fpm

Instale o MariaDB

MariaDB é um fork de código aberto do MySQL. Adicione o repositório MariaDB ao seu sistema, pois o repositório padrão do Ubuntu contém uma versão mais antiga do MariaDB.

sudo apt-key adv --yes --recv-keys --keyserver hkp://keyserver.ubuntu.com:80 0xF1656F24C74CD1D8
sudo add-apt-repository 'deb [arch=amd64,i386,ppc64el] http://mariadb.biz.net.id/repo/10.2/ubuntu xenial main'
sudo apt update

Instale o MariaDB. Durante a instalação, o instalador solicitará a senha do rootusuário do MySQL . Forneça uma senha forte.

sudo apt -y install mariadb-server

Antes de começarmos a usar o MariaDB, precisaremos ajustar um pouco a configuração. Abra o arquivo de configuração.

sudo nano /etc/mysql/conf.d/mariadb.cnf 

Adicione o seguinte código ao final do arquivo.

[mysqld]
innodb_file_per_table=1
sql-mode=""
lower_case_table_names=0

Reinicie o MariaDB e ative-o automaticamente no momento da inicialização.

sudo systemctl restart mariadb.service 
sudo systemctl enable mariadb.service

Antes de configurar o banco de dados, você precisará proteger a instância do MariaDB.

sudo mysql_secure_installation

Você será solicitado a senha root atual do MariaDB e será solicitado a alterar a rootsenha. Como já definimos uma senha forte para o rootusuário durante a instalação, pule-a respondendo " N". Para todas as outras perguntas, responda " Y". As perguntas feitas são auto-explicativas.

Entre no shell do MySQL como root.

mysql -u root -p

Forneça a senha para o usuário root do MariaDB efetuar login. Execute as seguintes consultas para criar um banco de dados e um usuário de banco de dados para a instalação do LibreNMS.

CREATE DATABASE librenms CHARACTER SET utf8 COLLATE utf8_general_ci;
CREATE USER 'librenms'@'localhost' IDENTIFIED BY 'StrongPassword';
GRANT ALL PRIVILEGES ON librenms.* TO 'librenms'@'localhost';
FLUSH PRIVILEGES;
EXIT;

Você pode substituir o nome do banco de dados librenms e o nome de usuário de librenms acordo com sua escolha. Certifique-se de alterar StrongPassword para uma senha muito forte.

Instale o LibreNMS

Além das dependências acima, o LibreNMS precisa de mais algumas dependências.

sudo apt -y install fping git imagemagick jwhois mtr graphviz nmap python-memcache python-mysqldb rrdtool snmp snmpd whois composer

Adicione um novo usuário não privilegiado ao aplicativo LibreNMS.

sudo useradd librenms -d /opt/librenms -M -r
sudo usermod -aG www-data librenms

O LibreNMS pode ser instalado diretamente, clonando seu repositório Github.

cd /opt
sudo git clone https://github.com/librenms/librenms.git librenms

Mude a propriedade.

sudo chown librenms:librenms -R /opt/librenms

Instale as dependências do PHP.

cd /opt/librenms
sudo su librenms -c "composer install"

O LibreNMS depende do SNMP para muitas tarefas. Como já instalamos o SNMP, copie o arquivo de configuração de exemplo para seu local.

sudo cp /opt/librenms/snmpd.conf.example /etc/snmp/snmpd.conf

Abra o arquivo de configuração no editor.

sudo nano /etc/snmp/snmpd.conf

Encontre esta linha.

com2sec readonly  default         RANDOMSTRINGGOESHERE

Edite o texto RANDOMSTRINGGOESHERE e substitua a sequência da comunidade por qualquer sequência de sua escolha. Por exemplo.

com2sec readonly  default         my-org

Lembre-se da string, pois será necessária mais tarde quando adicionarmos o primeiro dispositivo SNMP.

O SNMP também precisa de informações sobre a versão de distribuição. Baixe e instale o script para encontrar a versão da distribuição.

sudo curl -o /usr/bin/distro https://raw.githubusercontent.com/librenms/librenms-agent/master/snmp/distro
sudo chmod +x /usr/bin/distro

Inicie o serviço daemon SNMP e ative-o automaticamente no momento da inicialização.

sudo systemctl enable snmpd
sudo systemctl restart snmpd

Agora você precisará adicionar algumas entradas do crontab para executar as tarefas agendadas. Crie um novo arquivo de tarefa cron.

sudo cp /opt/librenms/librenms.nonroot.cron /etc/cron.d/librenms

Reinicie o serviço cron daemon.

sudo systemctl restart cron

Configure logrotate para que os arquivos de log sejam atualizados automaticamente ao longo do tempo.

sudo cp /opt/librenms/misc/librenms.logrotate /etc/logrotate.d/librenms

Por fim, defina a propriedade e as permissões apropriadas.

sudo chown -R librenms:www-data /opt/librenms
sudo chmod g+w -R /opt/librenms
sudo setfacl -d -m g::rwx /opt/librenms/rrd /opt/librenms/logs
sudo setfacl -R -m g::rwx /opt/librenms/rrd /opt/librenms/logs

Configurações SSL e Nginx VHost

Logins e outras informações enviadas pela interface da web do LibreNMS não são protegidas se a conexão não for criptografada com SSL. Vamos configurar o Nginx para usar o SSL gerado com o SSL gratuito Vamos criptografar.

Adicione o repositório Certbot.

sudo add-apt-repository --yes ppa:certbot/certbot
sudo apt-get update

Instale o Certbot, que é o aplicativo cliente do Let's Encrypt CA.

sudo apt -y install certbot

Nota : Para obter certificados da Let's Encrypt CA, o domínio para o qual os certificados devem ser gerados deve estar apontado para o servidor. Caso contrário, faça as alterações necessárias nos registros DNS do domínio e aguarde a propagação do DNS antes de fazer a solicitação de certificado novamente. O Certbot verifica a autoridade do domínio antes de fornecer os certificados.

Gere os certificados SSL.

sudo certbot certonly --webroot -w /var/www/html -d nms.example.com

Os certificados gerados provavelmente serão armazenados no /etc/letsencrypt/live/nms.example.com/diretório O certificado SSL será armazenado como fullchain.pem e a chave privada será armazenada como privkey.pem.

Vamos criptografar os certificados expiram em 90 dias; portanto, é recomendável configurar a renovação automática para os certificados usando uma tarefa cron.

Abra o arquivo de tarefa cron.

sudo crontab -e

Adicione a seguinte linha no final do arquivo.

30 5 * * 1 /usr/bin/certbot renew --quiet

O trabalho cron acima será executado toda segunda-feira às 05:30, horário local. Se o certificado estiver vencido, ele será renovado automaticamente.

Crie um novo host virtual.

sudo nano /etc/nginx/sites-available/librenms

Preencher o arquivo.

server {
    listen 80;
    server_name nms.example.com;
    return 301 https://$host$request_uri;
}
server {

    listen 443;
    server_name nms.example.com;

    ssl_certificate           /etc/letsencrypt/live/nms.example.com/fullchain.pem;
    ssl_certificate_key       /etc/letsencrypt/live/nms.example.com/privkey.pem;

    ssl on;
    ssl_session_cache  builtin:1000  shared:SSL:10m;
    ssl_protocols  TLSv1 TLSv1.1 TLSv1.2;
    ssl_ciphers HIGH:!aNULL:!eNULL:!EXPORT:!CAMELLIA:!DES:!MD5:!PSK:!RC4;
    ssl_prefer_server_ciphers on;

    access_log    /opt/librenms/logs/librenms.nginx.access.log;
    root        /opt/librenms/html;
    index       index.php;

    charset utf-8;
    gzip on;
    gzip_types text/css application/javascript text/javascript application/x-javascript image/svg+xml text/plain text/xsd text/xsl text/xml image/x-icon;
    location / {
        try_files $uri $uri/ /index.php?$query_string;
    }
    location /api/v0 {
        try_files $uri $uri/ /api_v0.php?$query_string;
    }
    location ~ \.php {
        include fastcgi.conf;
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
        fastcgi_pass unix:/run/php/php7.2-fpm.sock;
    }
    location ~ /\.ht {
        deny all;
    }
 }

Substitua nms.example.com por seu domínio real na configuração acima.

Ative a configuração recém-criada.

sudo ln -s /etc/nginx/sites-available/librenms /etc/nginx/sites-enabled/librenms

Reinicie o Nginx.

sudo systemctl restart nginx

Instalação usando WebUI

Para finalizar a instalação, abra https://nms.example.com no seu navegador favorito. Você verá que os requisitos foram atendidos. Forneça os detalhes do seu banco de dados e crie uma nova conta administrativa. Uma vez instalado, você receberá uma mensagem para validar a instalação. Clique no link e efetue login usando a conta de administrador. Você deve ver que tudo, exceto o " Poller" tem um Okstatus " ".

Monitore seus dispositivos usando o LibreNMS no Ubuntu 16.04

Agora, clique no link para adicionar um dispositivo. Na Add Deviceinterface " ", forneça o nome do host como o host local e deixe tudo como está. Forneça sua string de comunidade no campo da comunidade. Deve ser exatamente a mesma string que você forneceu snmpd.confdurante a configuração do SNMP.

Monitore seus dispositivos usando o LibreNMS no Ubuntu 16.04

Depois que o dispositivo for adicionado, você poderá ver os detalhes na Devicesguia " ". Da mesma forma, você pode adicionar mais dispositivos ao aplicativo LibreNMS para monitoramento "24 horas".



Leave a Comment

Como instalar a plataforma LiteCart Shopping Cart no Ubuntu 16.04

Como instalar a plataforma LiteCart Shopping Cart no Ubuntu 16.04

LiteCart é uma plataforma de carrinho de compras de código aberto e gratuita escrita em PHP, jQuery e HTML 5. É um software de comércio eletrônico simples, leve e fácil de usar

Configuração inicial segura do servidor Ubuntu 18.04

Configuração inicial segura do servidor Ubuntu 18.04

Introdução Neste tutorial, você aprenderá como configurar um nível básico de segurança em uma nova máquina virtual Vultr VC2 executando o Ubunt

Instalando o McMyAdmin no Ubuntu 14.10

Instalando o McMyAdmin no Ubuntu 14.10

McMyAdmin é um painel de controle do servidor Minecraft usado para administrar seu servidor. Embora o McMyAdmin seja gratuito, há várias edições, algumas das quais são pai

Configurar um TeamTalk Server no Linux

Configurar um TeamTalk Server no Linux

O TeamTalk é um sistema de conferência que permite aos usuários ter conversas de áudio / vídeo de alta qualidade, bate-papo por texto, transferir arquivos e compartilhar telas. É eu

Como instalar e configurar o CyberPanel no servidor CentOS 7

Como instalar e configurar o CyberPanel no servidor CentOS 7

Usando um sistema diferente? Introdução O CyberPanel é um dos primeiros painéis de controle do mercado, tanto de código aberto quanto de OpenLiteSpeed. What thi

Instale o Grafana no Ubuntu 16.04 LTS

Instale o Grafana no Ubuntu 16.04 LTS

Usando um sistema diferente? Introdução O Grafana é um software de código aberto que transforma vários feeds de sistemas como Graphite, Telegraf, um

Instale o phpBB com Apache no Ubuntu 16.04

Instale o phpBB com Apache no Ubuntu 16.04

PhpBB é um programa de boletim de código aberto. Este artigo mostra como instalar o phpBB em cima de um servidor Apache no Ubuntu 16.04. Foi writte

Como instalar o Foreman no Ubuntu 16.04 LTS

Como instalar o Foreman no Ubuntu 16.04 LTS

Usando um sistema diferente? O Foreman é uma ferramenta gratuita e de código aberto que ajuda na configuração e gerenciamento de servidores físicos e virtuais. Forema

Configurar um usuário não root com Sudo Access no Ubuntu

Configurar um usuário não root com Sudo Access no Ubuntu

Ter apenas um usuário, que é root, pode ser perigoso. Então vamos consertar isso. O Vultr nos dá a liberdade de fazer o que quisermos com nossos usuários e servidores

Instale o eSpeak no CentOS 7

Instale o eSpeak no CentOS 7

Usando um sistema diferente? O ESpeak pode gerar arquivos de áudio de conversão de texto em fala (TTS). Isso pode ser útil por vários motivos, como criar seu próprio Turim

Instalando o Fuel CMS no Ubuntu 16.04 LTS

Instalando o Fuel CMS no Ubuntu 16.04 LTS

Usando um sistema diferente? O Fuel CMS é um sistema de gerenciamento de conteúdo baseado em CodeIgniter. Seu código fonte está hospedado no GitHub. Este guia mostra como você pode

Como instalar o Couch CMS 2.0 em um VPS Debian 9 LAMP

Como instalar o Couch CMS 2.0 em um VPS Debian 9 LAMP

Usando um sistema diferente? O Couch CMS é um sistema de gerenciamento de conteúdo (CMS) simples e flexível, gratuito e de código aberto que permite que os web designers

Monitore seus dispositivos usando o LibreNMS no CentOS 7

Monitore seus dispositivos usando o LibreNMS no CentOS 7

Usando um sistema diferente? O LibreNMS é um sistema de monitoramento de rede de código aberto completo. Ele usa o SNMP para obter os dados de diferentes dispositivos. Uma variedade

Como usar o Sudo no Debian, CentOS e FreeBSD

Como usar o Sudo no Debian, CentOS e FreeBSD

Usar um usuário sudo para acessar um servidor e executar comandos no nível raiz é uma prática muito comum entre o Linux e o Unix Systems Administrator. O uso de um sud

Como instalar o RabbitMQ no CentOS 7

Como instalar o RabbitMQ no CentOS 7

Usando um sistema diferente? O RabbitMQ é um intermediário de mensagens de código aberto amplamente usado, escrito na linguagem de programação Erlang. Como um middleware orientado a mensagens

Como ativar o TLS 1.3 no Apache no Fedora 30

Como ativar o TLS 1.3 no Apache no Fedora 30

Usando um sistema diferente? O TLS 1.3 é uma versão do protocolo TLS (Transport Layer Security) publicada em 2018 como um padrão proposto no RFC 8446

Configurando um Chroot no Debian

Configurando um Chroot no Debian

Este artigo ensinará como configurar uma prisão chroot no Debian. Presumo que você esteja usando o Debian 7.x. Se você estiver executando o Debian 6 ou 8, isso pode funcionar, mas

Como instalar o PiVPN no Debian

Como instalar o PiVPN no Debian

Introdução Uma maneira fácil de configurar um servidor VPN no Debian é com o PiVPN. PiVPN é um instalador e wrapper para o OpenVPN. Ele cria comandos simples para você t

Configurar o Nginx-RTMP no CentOS 7

Configurar o Nginx-RTMP no CentOS 7

Usando um sistema diferente? O RTMP é ótimo para veicular conteúdo ao vivo. Quando o RTMP é emparelhado com o FFmpeg, os fluxos podem ser convertidos em várias qualidades. Vultr i

Como instalar e configurar o CyberPanel no Ubuntu 18.04 LTS

Como instalar e configurar o CyberPanel no Ubuntu 18.04 LTS

Usando um sistema diferente? Introdução O CyberPanel é um dos primeiros painéis de controle do mercado, tanto de código aberto quanto de OpenLiteSpeed. What thi

A IA pode lutar contra o aumento do número de ataques de ransomware

A IA pode lutar contra o aumento do número de ataques de ransomware

Os ataques de ransomware estão aumentando, mas a IA pode ajudar a lidar com os vírus de computador mais recentes? AI é a resposta? Leia aqui para saber se é AI boone ou bane

ReactOS: Este é o futuro do Windows?

ReactOS: Este é o futuro do Windows?

ReactOS, um sistema operacional de código aberto e gratuito está aqui com a versão mais recente. Será que ela pode atender às necessidades dos usuários modernos do Windows e derrubar a Microsoft? Vamos descobrir mais sobre esse estilo antigo, mas uma experiência de sistema operacional mais recente.

Fique conectado por meio do aplicativo WhatsApp Desktop 24 * 7

Fique conectado por meio do aplicativo WhatsApp Desktop 24 * 7

O Whatsapp finalmente lançou o aplicativo Desktop para usuários de Mac e Windows. Agora você pode acessar o Whatsapp do Windows ou Mac facilmente. Disponível para Windows 8+ e Mac OS 10.9+

Como a IA pode levar a automação de processos ao próximo nível?

Como a IA pode levar a automação de processos ao próximo nível?

Leia isto para saber como a Inteligência Artificial está se tornando popular entre as empresas de pequena escala e como está aumentando as probabilidades de fazê-las crescer e dar vantagem a seus concorrentes.

A atualização do suplemento do macOS Catalina 10.15.4 está causando mais problemas do que resolvendo

A atualização do suplemento do macOS Catalina 10.15.4 está causando mais problemas do que resolvendo

Recentemente, a Apple lançou o macOS Catalina 10.15.4, uma atualização suplementar para corrigir problemas, mas parece que a atualização está causando mais problemas, levando ao bloqueio de máquinas mac. Leia este artigo para saber mais

13 Ferramentas de Extração de Dados Comerciais de Big Data

13 Ferramentas de Extração de Dados Comerciais de Big Data

13 Ferramentas de Extração de Dados Comerciais de Big Data

O que é um sistema de arquivos de registro no diário e como ele funciona?

O que é um sistema de arquivos de registro no diário e como ele funciona?

Nosso computador armazena todos os dados de uma maneira organizada conhecida como sistema de arquivos Journaling. É um método eficiente que permite ao computador pesquisar e exibir arquivos assim que você clicar em search.https: //wethegeek.com/? P = 94116 & preview = true

Singularidade tecnológica: um futuro distante da civilização humana?

Singularidade tecnológica: um futuro distante da civilização humana?

À medida que a ciência evolui em um ritmo rápido, assumindo muitos de nossos esforços, os riscos de nos sujeitarmos a uma singularidade inexplicável também aumentam. Leia, o que a singularidade pode significar para nós.

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

O impacto da inteligência artificial na saúde 2021

O impacto da inteligência artificial na saúde 2021

A IA na área da saúde deu grandes saltos nas últimas décadas. Portanto, o futuro da IA ​​na área da saúde ainda está crescendo dia a dia.