Skip to content

Latest commit

 

History

History
111 lines (75 loc) · 4.83 KB

Readme.md

File metadata and controls

111 lines (75 loc) · 4.83 KB

Docker Setup

This is a Docker setup for the Elastic stack, useful to demonstrate examples in a workshop.

The following Docker containers are available

  • Elasticsearch instances (7.8.1), a three node cluster, accessible from host, most examples only require first instance
  • cerebro
  • curator (for index management)
  • filebeat (to generate logs)
  • kibana
  • logindexer (Logstash to ingest logs into ES)
  • metricbeat (monitors redis)
  • redis (acts as a buffer between filebeat & logstash)

For more details check docker-compose.yml configuration. Most examples in a workshop only require a single Elasticsearch node.

The main reason that elasticsearch01 is the only master node is that it allows to start this container as a single node cluster. When starting containers elasticsearch02 and elasticsearch03 afterwards it does not set the minimum of master nodes from 1 to 2. This is mainly for presentation purposes and is not recommended in a production environment where all instances in a 3 nodes cluster should have the master role.

Setup

This repository provides a Docker configuration to set up a local test environment.

  • install Docker for your OS if not already present
  • alternatively use a VM or install Elasticsearch locally on your system

Most examples require only a single Elasticsearch instance, therefore it's sufficient to start one instance and Cerebro to check the cluster.

docker-compose up --build elasticsearch01 cerebro

The containers cerebro and kibana provide graphical interfaces into the Elasticsearch cluster. To start these run

docker-compose up -d --build cerebro kibana

These services can be accessed via web browser.

! Some examples may require to start other containers as well.

For example to start all 3 Elasticsearch nodes as a cluster run

docker-compose up -d --build elasticsearch01 elasticsearch02 elasticsearch03

To remove all containers and their volumes use the following Docker Compose command:

docker-compose down -v --remove-orphans

This removes all Docker containers and all the data folders defined in the docker-compose.yml. This is useful when the cluster has seen at least one additional master node and may not start as a single node cluster afterwards.

References

Redis

To check if the Redis instance is reachable, for example from within the filebeat / app docker container:

# https://stackoverflow.com/questions/33243121/abuse-curl-to-communicate-with-redis
$ exec 3<>/dev/tcp/redis/6379 && echo -e "PING\r\n" >&3 && head -c 7 <&3
+ PONG

This returns +PONG as response if successful.

To check if the filebeat configuration is loaded successfully, run filebeat with configuration:

$ filebeat -c filebeat.yml -e -d "*"

To emit events in the app container, run the following command

# connect into the running app container
$ docker exec -ti docker_app_1 /bin/bash
$ for i in {1..1000}; do echo "Hello World\n" >> /var/log/filebeat.log; done
$ for i in {1..1000}; do echo "BLUBB HURRA\n" >> /var/log/filebeat.log; done

all events are read from the filebeat.log log file and are send to Redis.

Resources / Links