This README is adapted from the original repo by namvu80ap/docker-elk-filebeat.
Run version 7.8.0 of the ELK (Elasticsearch, Filebeat, Kibana) stack with Docker and Docker Compose.
It will give you the ability to analyze any data set by using the searching/aggregation capabilities of Elasticsearch and the visualization power of Kibana.
Based on the official Docker images on Dockerhub:
Note: In case you switched branch or updated a base image - you may need to run docker-compose build
first
Start the ELK stack using docker-compose
:
You can also choose to run it in background (detached mode):
$ docker-compose -f docker-compose-elk.yml up -d
Give Kibana a few seconds to initialize, then access the Kibana web UI by hitting http://localhost:5601 with a web browser.
By default, the stack exposes the following ports:
- 9200: Elasticsearch HTTP
- 9300: Elasticsearch TCP transport
- 5601: Kibana
Notice: Kibana will ask you for basic auth username/password saved in filebeat.yml
When Kibana launches for the first time, it is not configured with any index pattern.
NOTE: You need to inject data into Logstash before being able to configure a Logstash index pattern via the Kibana web UI. Then all you have to do is hit the Create button.
Refer to Connect Kibana with Elasticsearch for detailed instructions about the index pattern configuration.
NOTE: Configuration is not dynamically reloaded, you will need to restart the stack after any change in the configuration of a component.
The Filebeat configuration is stored in filebeat/filebeat.yml
.
The Elasticsearch configuration is stored in elasticsearch/config/elasticsearch.yml
.
The data stored in Elasticsearch will be persisted after container reboot but not after container removal.
In order to persist Elasticsearch data even after removing the Elasticsearch container, you'll have to mount a volume on
your Docker host. Update the elasticsearch
service declaration to:
elasticsearch:
volumes:
- /path/to/storage:/usr/share/elasticsearch/data
This will store Elasticsearch data inside /path/to/storage
.