Configure sua própria rede privada com o OpenVPN
O Vultr oferece uma incrível conectividade de rede privada para servidores executando no mesmo local. Mas às vezes você quer dois servidores em países diferentes
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.
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 básico usando o guia Como atualizar o CentOS 7 . Depois que seu sistema for atualizado, continue com a instalação das dependências.
O front end do LibreNMS é basicamente escrito em PHP, portanto, precisaremos instalar um servidor 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 yum -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 YUM padrão contém uma versão mais antiga do PHP.
sudo rpm -Uvh http://rpms.remirepo.net/enterprise/remi-release-7.rpm
sudo yum -y install yum-utils
sudo yum-config-manager --enable remi-php72
Instale o PHP versão 7.2 junto com os módulos exigidos pelo LibreNMS.
sudo yum -y install php php-cli php-common php-curl php-fpm php-gd php-mcrypt php-mysql php-process php-snmp php-xml php-zip
Abra o arquivo de configuração carregado pelo PHP em um editor.
sudo nano /etc/php.ini
Encontre as seguintes linhas, remova o comentário e altere seu valor conforme mostrado.
;cgi.fix_pathinfo=1
memory_limit = 128M
;date.timezone =
Use esses valores, substitua Asia/Kolkata
pelo fuso horário local.
cgi.fix_pathinfo=0
memory_limit = -1
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
Agora abra o arquivo de configuração do PHP-FPM.
sudo nano /etc/php-fpm.d/www.conf
Encontre a seguinte linha.
listen = 127.0.0.1:9000
Substitua-o pela seguinte linha.
listen = /var/run/php-fpm/php-fpm.sock
Por padrão, o PHP-FPM está configurado para o usuário do servidor da web Apache. Mude o usuário para nginx
.
user = nginx
group = nginx
Além disso, remova o comentário das seguintes linhas.
listen.owner = nobody
listen.group = nobody
Salve o arquivo e saia do editor. Reinicie o PHP-FPM e ative-o no momento da inicialização.
sudo systemctl restart php-fpm
sudo systemctl enable php-fpm
Defina a propriedade apropriada para o arquivo de soquete.
sudo chown nginx:nginx /var/run/php-fpm/php-fpm.sock
MariaDB é um fork do MySQL. Adicione o repositório MariaDB ao seu sistema. O yum
repositório padrão contém uma versão mais antiga do MariaDB.
echo "[mariadb]
name = MariaDB
baseurl = http://yum.mariadb.org/10.2/centos7-amd64
gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
gpgcheck=1" | sudo tee /etc/yum.repos.d/mariadb.repo
Instale o MariaDB.
sudo yum -y install mariadb mariadb-server
Agora, abra o arquivo de configuração do MySQL.
sudo nano /etc/my.cnf
Adicione as seguintes linhas no final do bloco.
[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
sudo systemctl enable mariadb
Antes de configurar o banco de dados, você precisará proteger o MariaDB primeiro.
sudo mysql_secure_installation
Você será solicitado a senha de root atual do MariaDB. Por padrão, não há senha de root em uma instalação nova do MariaDB. Pressione a tecla " Enter
" para continuar. Defina uma senha forte para o root
usuário do servidor MariaDB e responda " Y
" a todas as outras perguntas feitas. 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.
Além das dependências acima, o LibreNMS precisa de mais algumas dependências. Instale-os executando.
sudo yum -y install cronie fping git ImageMagick jwhois mtr MySQL-python net-snmp net-snmp-utils nmap python-memcached rrdtool
Adicione um novo usuário não privilegiado ao aplicativo LibreNMS.
sudo useradd librenms -d /opt/librenms -M -r
sudo usermod -a -G librenms nginx
O LibreNMS pode ser instalado diretamente, clonando seu repositório Github.
cd /opt
sudo git clone https://github.com/librenms/librenms.git librenms
Corrija a propriedade.
sudo chown librenms:librenms -R /opt/librenms
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 nano /etc/cron.d/librenms
Preencha o arquivo com o seguinte texto.
33 */6 * * * librenms /opt/librenms/cronic /opt/librenms/discovery-wrapper.py 1
*/5 * * * * librenms /opt/librenms/discovery.php -h new >> /dev/null 2>&1
*/5 * * * * librenms /opt/librenms/cronic /opt/librenms/poller-wrapper.py 16
15 0 * * * librenms /opt/librenms/daily.sh >> /dev/null 2>&1
* * * * * librenms /opt/librenms/alerts.php >> /dev/null 2>&1
*/5 * * * * librenms /opt/librenms/poll-billing.php >> /dev/null 2>&1
01 * * * * librenms /opt/librenms/billing-calculate.php >> /dev/null 2>&1
*/5 * * * * librenms /opt/librenms/check-services.php >> /dev/null 2>&1
Reinicie o serviço cron daemon.
sudo systemctl restart crond
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:nginx /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
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 SSL gerado com o SSL gratuito Let's Encrypt.
Instale o Certbot, que é o aplicativo cliente do Let's Encrypt CA.
sudo yum -y install certbot
Antes de solicitar os certificados, você precisará permitir a porta 80
e 443
/ ou padrão HTTP
e HTTPS
serviços através do firewall.
sudo firewall-cmd --zone=public --add-service=http --permanent
sudo firewall-cmd --zone=public --add-service=https --permanent
sudo firewall-cmd --reload
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 /usr/share/nginx/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/conf.d/nms.example.com.conf
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:/var/run/php-fpm/php-fpm.sock;
}
location ~ /\.ht {
deny all;
}
}
Substitua nms.example.com
por seu domínio real na configuração acima.
Reinicie o Nginx.
sudo chown nginx:nginx /var/lib/php/session
sudo systemctl restart nginx
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ê verá que tudo, exceto o " Poller
" tem um Ok
status " ".
Agora, clique no link para adicionar um dispositivo. Na Add Device
interface " ", 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.conf
durante a configuração do SNMP.
Depois que o dispositivo for adicionado, você poderá ver os detalhes na Devices
guia " ".
Da mesma forma, você pode adicionar mais dispositivos ao aplicativo LibreNMS para monitoramento "24 horas".
O Vultr oferece uma incrível conectividade de rede privada para servidores executando no mesmo local. Mas às vezes você quer dois servidores em países diferentes
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
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
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
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
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
Usando um sistema diferente? Gradle é um conjunto de ferramentas de automação de compilação de código aberto e gratuito baseado nos conceitos do Apache Ant e Apache Maven. Gradle fornece
Usando um sistema diferente? Neste guia, veremos como configurar um servidor FTP (ProFTPd) para transferir arquivos entre o seu PC e o seu servidor.
Usando um sistema diferente? O Netdata é uma estrela em ascensão no campo do monitoramento de métricas do sistema em tempo real. Comparado com outras ferramentas do mesmo tipo, o Netdata:
Usando um sistema diferente? O Apache Cassandra é um sistema de gerenciamento de banco de dados NoSQL gratuito e de código aberto, projetado para fornecer escalabilidade, alta
Neste tutorial, aprenda como configurar um servidor multiplayer Just Cause 2. Pré-requisitos Verifique se o sistema está totalmente atualizado antes de começarmos
Usando um sistema diferente? Neste tutorial, explicarei como configurar um servidor Starbound no CentOS 7. Pré-requisitos Você precisa ser o proprietário deste jogo
O ZNC é um segurança IRC gratuito e de código aberto que permanece permanentemente conectado a uma rede para que os clientes possam receber mensagens enviadas enquanto estiverem offline. Thi
O Django é uma estrutura Python popular para escrever aplicativos da web. Com o Django, você pode criar aplicativos mais rapidamente, sem reinventar a roda. Se você quiser você
Outubro é um sistema de gerenciamento de conteúdo de código aberto baseado no Laravel PHP Framework. Com uma interface elegante e uma arquitetura modular concisa
Após alterar a porta SSH, configurar a batida na porta e fazer outros ajustes para a segurança SSH, talvez haja mais uma maneira de protegê-lo
Introdução O MyCLI é um cliente de linha de comando para MySQL e MariaDB que permite concluir automaticamente e ajuda na sintaxe de seus comandos SQL. MyCL
Usando um sistema diferente? O Directus 6.4 CMS é um sistema de gerenciamento de conteúdo sem cabeça (CMS) poderoso e flexível, gratuito e de código aberto que fornece
Usando um sistema diferente? O Reader Self 3.5 é um leitor de RSS auto-hospedado, simples e flexível, gratuito e de código aberto, e uma alternativa ao Google Reader. Leitor Sel
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, 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.
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+
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.
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
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
À 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
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.