Compartilhe que você está se especializando

Aqui falaremos sobre os procedimentos de instalação do ELK 5 em CentOS. Deixaremos um exemplo um pouco longo do Logstash apenas para que você entenda e compreenda algumas possibilidades (no site é possível consultar mais tipos de entradas, filtros e saídas)

Antes de mais nada, será necessário o Java, para instalar execute:

yum install java-1.8.0-openjdk policycoreutils-python -y

Para instalar o Elasticsearch, execute os comandos abaixo:

rpm -ivh http://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-5.3.0.rpm

sed -i "s/#network.host: 192.168.0.1/network.host: localhost/g" /etc/elasticsearch/elasticsearch.yml
ln -s /usr/share/elasticsearch/bin/elasticsearch-plugin /usr/bin/elasticsearch-plugin

elasticsearch-plugin install x-pack

systemctl daemon-reload

systemctl enable elasticsearch.service
systemctl start elasticsearch

Para instalar o logstash, execute os comandos abaixo:

rpm -ivh http://artifacts.elastic.co/downloads/logstash/logstash-5.3.0.rpm

vi /etc/logstash/conf.d/logstash.conf

Aperte a tecla INSERT do teclado para entrar em modo de edição e deixa-lo da seguinte forma:

input {
beats {
port => 5044
type => “ex_msg_trk”
congestion_threshold => “40”
}
udp {
port => 514
}
udp {
type => “Exchange”
port => 5141
}
}
filter {
if [type] == “ex_msg_trk” {
grok {
match => { “message” => “(%{TIMESTAMP_ISO8601:date-time})?,(%{IPORHOST:client-ip})?,(%{IPORHOST:client-hostname})?,(%{IPORHOST:server-ip})?,(%{IPORHOST:server-hostname})?,(%{GREEDYDATA:source-context})?,(%{GREEDYDATA:connector-id})?,(%{WORD:source})?,(%{WORD:event-id})?,(%{NUMBER:internal-message-id})?,(%{GREEDYDATA:message-id})?,(%{GREEDYDATA:recipient-address})?,(%{GREEDYDATA:recipient-status})?,(%{NUMBER:total-bytes})?,(%{NUMBER:recipient-count})?,(%{GREEDYDATA:related-recipient-address})?,(%{GREEDYDATA:reference})?,(%{GREEDYDATA:message-subject})?,(%{GREEDYDATA:sender-address})?,(%{GREEDYDATA:return-path})?,(%{GREEDYDATA:message-info})?,(%{WORD:directionality})?,(%{GREEDYDATA:tenant-id})?,(%{IPORHOST:original-client-ip})?,(%{IPORHOST:original-server-ip})?,(%{GREEDYDATA:custom-data})?” }
}
mutate {
convert => [ “total-bytes”, “integer” ]
convert => [ “recipient-count”, “integer” ]
split => [“recipient-address”, “;”]
split => [ “source-context”, “;” ]
split => [ “custom_data”, “;” ]
}
}
if [type] == “Exchange” {
csv {
add_tag => [ ‘exh_msg_trk’ ]
columns => [‘logdate’, ‘client_ip’, ‘client_hostname’,  ‘server_ip’, ‘server_hostname’, ‘source_context’, ‘connector_id’, ‘source’, ‘event_id’, ‘internal_message_id’, ‘message_id’, ‘network_message_id’, ‘recipient_address’, ‘recipient_status’, ‘total_bytes’, ‘recipient_count’, ‘related_recipient_address’, ‘reference’, ‘message_subject’, ‘sender_address’, ‘return_path’, ‘message_info’, ‘directionality’, ‘tenant_id’, ‘original_client_ip’, ‘original_server_ip’, ‘custom_data’]
remove_field => [ “logdate” ]
}
grok {
match => [ “message”, “%{TIMESTAMP_ISO8601:timestamp}” ]
}
mutate {
convert => [ “total_bytes”, “integer” ]
convert => [ “recipient_count”, “integer” ]
split => [“recipient_address”, “;”]
split => [ “source_context”, “;” ]
split => [ “custom_data”, “;” ]
}
date {
match => [ “timestamp”, “ISO8601” ]
timezone => “Europe/London”
remove_field => [ “timestamp” ]
}
if “_grokparsefailure” in [tags] {
drop { }
}
}
if [type] == “syslog” {
grok {
match => { “message” => “%{SYSLOGLINE}” }
}
date {
match => [ “timestamp”, “MMM  d HH:mm:ss”, “MMM dd HH:mm:ss” ]
}
}
}
output {
elasticsearch {
hosts => localhost
}
stdout {
codec => rubydebug
}
}

Ao final, pressionar a tecla ESC para sair do modo de edição, digitar :wq! e pressionar ENTER para sair e salvar. Agora execute:

ln -s /usr/share/logstash/bin/logstash /usr/bin/logstash
/usr/share/logstash/bin/logstash-plugin install logstash-input-beats

/usr/share/logstash/bin/logstash-plugin install logstash-input-udp

/usr/share/logstash/bin/logstash-plugin install logstash-output-elasticsearch

systemctl daemon-reload

systemctl enable logstash
systemctl start logstash

Para instalar o Kibana, execute os comandos abaixo:

rpm -ivh http://artifacts.elastic.co/downloads/kibana/kibana-5.3.0-x86_64.rpm

sed -i "s/server.port: 5601/server.port: 80/g" /etc/kibana/kibana.yml
sed -i "s/#server.port: 5601/server.port: 5601/g" /etc/kibana/kibana.yml
sed -i "s/#server.host: \"localhost\"/server.host: \"SEU_IP\"/g" /etc/kibana/kibana.yml
sed -i "s/#elasticsearch.url: \"http:\/\/localhost:9200\"/elasticsearch.url: \"http:\/\/localhost:9200\"/g" /etc/kibana/kibana.yml

systemctl enable kibana
systemctl start kibana

ln -s /usr/share/kibana/bin/kibana-plugin /usr/bin/kibana-plugin
kibana-plugin install x-pack

Para acessar, abra o endereço http://IP_SEU_SERVIDOR:5061 (usuário elastic e senha changeme).

Fontes/Referências

https://www.elastic.co/guide/en/elasticsearch/reference/current/rpm.html
https://www.elastic.co/guide/en/x-pack/current/installing-xpack.html
https://www.tecmint.com/install-elasticsearch-logstash-and-kibana-elk-stack-on-centos-rhel-7/

Mais Informações

Esperamos ter te ajudado e estaremos sempre a disposição para mais informações.

Se você tem interesse em algum assunto específico, tem alguma dúvida, precisa de ajuda, ou quer sugerir um post, entre em contato conosco pelo e-mail equipe@nvlan.com.br.

NVLAN - Consultoria