Como instalar o servidor Graylog no CentOS 7

O servidor Graylog é um pacote de software de gerenciamento de log de código aberto pronto para empresas. Ele coleta logs de várias fontes e os analisa para descobrir e resolver problemas. O servidor Graylog é basicamente a combinação de Elasticsearch, MongoDB e Graylog. O Elasticsearch é um aplicativo de código aberto muito popular para armazenar texto e fornecer recursos de pesquisa muito poderosos. O MongoDB é um aplicativo de código aberto para armazenar dados no formato NoSQL. O Graylog coleta logs de várias fontes e fornece um painel baseado na Web para gerenciar e pesquisar através dos logs. Graylog também fornece uma API REST para configuração e dados. Ele fornece um painel configurável que pode ser usado para visualizar métricas e observar tendências usando estatísticas de campo, valores rápidos e gráficos de um local central.

Neste tutorial, você aprenderá a instalar o Graylog Server no CentOS 7. Este guia foi escrito para o Graylog Server 2.3, mas também pode funcionar em versões mais recentes. Você também aprenderá a instalar Java, Elasticsearch e MongoDB. Também protegeremos a instância do MongoDB e configuraremos um proxy reverso Nginx para o painel e a API baseados na Web.

Pré-requisitos

  • Uma instância do servidor Vultr CentOS 7 com pelo menos 4 GB de RAM.
  • Um usuário sudo .

Neste tutorial, usaremos 192.0.2.1como o endereço IP público do servidor e graylog.example.comcomo o nome de domínio apontado para o servidor. Substitua todas as ocorrências 192.0.2.1pelo seu endereço IP público do Vultr e graylog.example.compelo seu nome de domínio 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 do Java.

Instale Java

O Elasticsearch requer que o Java 8 seja executado. Ele suporta Oracle Java e OpenJDK, mas é sempre recomendável usar o Oracle Java sempre que possível. A Oracle fornece pacotes RPM prontos para instalar. Faça o download do Oracle JDK RPM:

wget --no-cookies --no-check-certificate --header "Cookie:oraclelicense=accept-securebackup-cookie" "http://download.oracle.com/otn-pub/java/jdk/8u144-b01/090f390dda5b47b9b721c7dfaa008135/jdk-8u144-linux-x64.rpm"

Instale o pacote RPM.

sudo yum -y install jdk-8u144-linux-x64.rpm

Se o Java foi instalado com sucesso, você deve poder verificar sua versão.

java -version

Você verá a seguinte saída.

[user@vultr ~]$ java -version
java version "1.8.0_144"
Java(TM) SE Runtime Environment (build 1.8.0_144-b01)
Java HotSpot(TM) 64-Bit Server VM (build 25.144-b01, mixed mode)

Conjunto JAVA_HOMEe JRE_HOMEvariável de ambiente executando:

echo "export JAVA_HOME=/usr/java/jdk1.8.0_144/" >> ~/.bash_profile
echo "export JRE_HOME=/usr/java/jdk1.8.0_144/jre" >> ~/.bash_profile

Agora, origine o arquivo usando o seguinte comando.

source ~/.bash_profile

Execute o echo $JAVA_HOMEcomando para verificar se a variável de ambiente está configurada ou não.

[user@vultr ~]$ echo $JAVA_HOME
/usr/java/jdk1.8.0_144/

Instale o Elasticsearch

O Elasticsearch é um aplicativo distribuído, em tempo real, escalável e altamente disponível, usado para armazenar os logs e pesquisar por eles. Ele armazena os dados em índices e a pesquisa através dos dados é muito rápida. Ele fornece vários conjuntos de APIs, como HTTP RESTful API e API Java nativa. O Elasticsearch pode ser instalado diretamente através do repositório Elasticsearch. Crie um novo arquivo de repositório para o Elasticsearch.

sudo nano /etc/yum.repos.d/elasticsearch.repo

Preencha o arquivo com o seguinte conteúdo.

[elasticsearch-5.x]
name=Elasticsearch repository for 5.x packages
baseurl=https://artifacts.elastic.co/packages/5.x/yum
gpgcheck=1
gpgkey=https://artifacts.elastic.co/GPG-KEY-elasticsearch
enabled=1
autorefresh=1
type=rpm-md

Importe a chave PGP usada para assinar os pacotes. Isso garantirá a integridade dos pacotes.

sudo rpm --import https://artifacts.elastic.co/GPG-KEY-elasticsearch

Instale o pacote Elasticsearch:

sudo yum -y install elasticsearch

Após a instalação do pacote, abra o arquivo de configuração padrão do Elasticsearch.

sudo nano /etc/elasticsearch/elasticsearch.yml

Encontre a linha a seguir, remova o comentário e altere o valor de my-applicationpara graylog.

cluster.name: graylog

Você pode iniciar o Elasticsearch e permitir que ele inicie automaticamente no momento da inicialização:

sudo systemctl enable elasticsearch
sudo systemctl start elasticsearch

O Elasticsearch agora está em execução na porta 9200. Verifique se está funcionando corretamente executando:

curl -XGET 'localhost:9200/?pretty'

Você deve ver uma saída semelhante à seguinte.

[user@vultr ~]$ curl -XGET 'localhost:9200/?pretty'
{
  "name" : "-kYzFA9",
  "cluster_name" : "graylog",
  "cluster_uuid" : "T3JQKehzSqmLThlVkEKPKg",
  "version" : {
    "number" : "5.5.1",
    "build_hash" : "19c13d0",
    "build_date" : "2017-07-18T20:44:24.823Z",
    "build_snapshot" : false,
    "lucene_version" : "6.6.0"
  },
  "tagline" : "You Know, for Search"
}

Se você encontrar erros, aguarde alguns segundos e tente novamente, pois o Elasticsearch leva algum tempo para concluir seu processo de inicialização. O Elasticsearch agora está instalado e funcionando corretamente.

Instale o MongoDB

O MongoDB é um servidor de banco de dados NoSQL gratuito e de código aberto. Diferentemente do banco de dados tradicional que usa tabelas para organizar seus dados, o MongoDB é orientado a documentos e usa documentos semelhantes a JSON sem esquemas. O Graylog usa o MongoDB para armazenar sua configuração e meta informações. Pode ser instalado diretamente através do repositório MongoDB. Crie um novo arquivo de repositório para o MongoDB.

sudo nano /etc/yum.repos.d/mongodb.repo

Preencha o arquivo com o seguinte conteúdo.

[mongodb-org-3.4]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/3.4/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-3.4.asc

Instale o MongoDB executando:

sudo yum -y install mongodb-org

Inicie o servidor MongoDB e ative-o automaticamente.

sudo systemctl start mongod
sudo systemctl enable mongod

Instale o servidor Graylog

Faça o download do repositório mais recente para o servidor Graylog.

sudo rpm -Uvh https://packages.graylog2.org/repo/packages/graylog-2.3-repository_latest.rpm
sudo yum -y update

Instale o Graylog executando:

sudo yum -y install graylog-server

O servidor Graylog está agora instalado no seu servidor. Antes de iniciá-lo, você precisará configurar algumas coisas.

Configurar Graylog

Instale o pwgenutilitário para gerar senhas fortes.

sudo yum -y install pwgen

Agora gere um segredo de senha forte.

pwgen -N 1 -s 96

Você produzirá semelhante a:

[user@vultr ~]$ pwgen -N 1 -s 96
pJqhNbdEY9FtNBfFUtq20lG2m9daacmsZQr59FhyoA0Wu3XQyVZcu5FedPZ9eCiDfjdiYWfRcEQ7a36bVqxSyTzcMMx5Rz8v

Além disso, gere um hash de 256 bits para a senha do adminusuário root :

echo -n StrongPassword | sha256sum

Substitua StrongPasswordpela senha que você deseja definir para o adminusuário. Você verá:

[user@vultr ~]$ echo -n StrongPassword | sha256sum
05a181f00c157f70413d33701778a6ee7d2747ac18b9c0fbb8bd71a62dd7a223  -

Abra o arquivo de configuração Graylog:

sudo nano /etc/graylog/server/server.conf

Encontre password_secret =, copie e cole a senha gerada por meio do pwgencomando Localize root_password_sha2 =, copie e cole o hash SHA convertido de 256 bits da sua senha de administrador. Encontre #root_email =, descomente e forneça seu endereço de e-mail. Remova o comentário e defina seu fuso horário em root_timezone. Por exemplo:

password_secret = pJqhNbdEY9FtNBfFUtq20lG2m9daacmsZQr59FhyoA0Wu3XQyVZcu5FedPZ9eCiDfjdiYWfRcEQ7a36bVqxSyTzcMMx5Rz8v
root_password_sha2 = 05a181f00c157f70413d33701778a6ee7d2747ac18b9c0fbb8bd71a62dd7a223
root_email = [email protected]
root_timezone = Asia/Kolkata

Ative a interface Graylog baseada na Web, descomentando #web_enable = falsee configurando o valor para true. Remova o comentário e altere as seguintes linhas, conforme especificado.

rest_listen_uri = http://0.0.0.0:9000/api/
rest_transport_uri = http://45.76.214.19:9000/api/
web_enable = true
web_listen_uri = http://0.0.0.0:9000/

Salve o arquivo e saia do seu editor de texto.

Reinicie o serviço Graylog executando:

sudo systemctl restart graylog-server

Configurar o Nginx como um proxy reverso

Por padrão, a interface da web Graylog escuta localhostna porta 9000 e a API escuta na porta 9000 com URL /api. Neste tutorial, usaremos o Nginx como proxy reverso para que o aplicativo possa ser acessado via porta HTTP padrão. Instale o servidor da web Nginx executando:

sudo yum -y install nginx

Abra o host virtual padrão digitando.

sudo nano /etc/nginx/nginx.conf

Localize o serverbloco abaixo httpe substitua o serverbloco inteiro pelas seguintes linhas.

server
{
    listen 80 default_server;
    listen [::]:80 default_server ipv6only=on;
    server_name graylog.example.com 192.0.2.1;

    location / {
      proxy_set_header Host $http_host;
      proxy_set_header X-Forwarded-Host $host;
      proxy_set_header X-Forwarded-Server $host;
      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
      proxy_set_header X-Graylog-Server-URL http://$server_name/api;
      proxy_pass       http://127.0.0.1:9000;
    }
}

Inicie o Nginx e permita que ele inicie automaticamente no momento da inicialização:

sudo systemctl start nginx
sudo systemctl enable nginx

Configurar firewall e SELinux

Se você estiver executando um firewall no seu servidor, precisará configurá-lo para definir uma exceção para determinadas portas. Permita que o serviço Elasticsearch e o proxy reverso Nginx se conectem de fora da rede.

sudo firewall-cmd --zone=public --permanent --add-service=http
sudo firewall-cmd --zone=public --permanent --add-port=9200/tcp
sudo firewall-cmd --reload

Se você tiver o SELinux ativado no seu sistema, precisará adicionar algumas exceções nas políticas do SELinux.

sudo setsebool -P httpd_can_network_connect 1
sudo semanage port -a -t http_port_t -p tcp 9000
sudo semanage port -a -t http_port_t -p tcp 9200
sudo semanage port -a -t mongod_port_t -p tcp 27017

Conclusão

A instalação e a configuração básica do servidor Graylog estão concluídas. Agora você pode acessar o servidor Graylog no http://192.0.2.1ou http://graylog.example.comse você tiver o DNS configurado. Entre usando o nome de usuário admine a versão em texto sem formatação da senha que você definiu root_password_sha2anteriormente.

Parabéns - você tem um servidor Graylog totalmente funcional instalado no servidor CentOS 7.



Leave a Comment

Configure sua própria rede privada com o OpenVPN

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

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

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

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 o Gradle no CentOS 7

Como instalar o Gradle no CentOS 7

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

Instale um servidor FTP com ProFTPd no CentOS 6 ou CentOS 7

Instale um servidor FTP com ProFTPd no CentOS 6 ou CentOS 7

Usando um sistema diferente? Neste guia, veremos como configurar um servidor FTP (ProFTPd) para transferir arquivos entre o seu PC e o seu servidor.

Instalando o Netdata no CentOS 7

Instalando o Netdata no CentOS 7

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:

Como instalar o Apache Cassandra 3.11.x no CentOS 7

Como instalar o Apache Cassandra 3.11.x no CentOS 7

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

Como instalar um servidor Just Cause 2 (JC2-MP) no CentOS 7

Como instalar um servidor Just Cause 2 (JC2-MP) no CentOS 7

Neste tutorial, aprenda como configurar um servidor multiplayer Just Cause 2. Pré-requisitos Verifique se o sistema está totalmente atualizado antes de começarmos

Como instalar o servidor Starbound no CentOS 7

Como instalar o servidor Starbound no CentOS 7

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

Instalando e configurando o ZNC no CentOS 7

Instalando e configurando o ZNC no CentOS 7

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

Como instalar o Django no CentOS 7

Como instalar o Django no CentOS 7

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ê

Como instalar o CMS de outubro no CentOS 7

Como instalar o CMS de outubro no CentOS 7

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

Como configurar a autenticação de dois fatores (2FA) para SSH no CentOS 6 usando o Google Authenticator

Como configurar a autenticação de dois fatores (2FA) para SSH no CentOS 6 usando o Google Authenticator

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

Como instalar o MyCLI no Linux (CentOS, Debian, Fedora e Ubuntu)

Como instalar o MyCLI no Linux (CentOS, Debian, Fedora e Ubuntu)

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

Como instalar o Directus 6.4 CMS em um CentOS 7 LAMP VPS

Como instalar o Directus 6.4 CMS em um CentOS 7 LAMP VPS

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

Como instalar o Reader Self 3.5 RSS Reader em um CentOS 7 LAMP VPS

Como instalar o Reader Self 3.5 RSS Reader em um CentOS 7 LAMP VPS

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

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.