Note: This release stores logstash config files in
/opt/logstash/conf.d/
. Please update any references to/opt/logstash.conf
in your existing deployment configs./opt/logstash/conf.d/
will be used from this release,0.11.0
, forward.
This is a highly configurable logstash (1.4.2) image running Elasticsearch (1.1.1) and Kibana (3.0.1).
To run the image, you have to first decide on one of three Elasticsearch configurations:
- Use the embedded Elasticsearch server
- Use a linked container running Elasticsearch
- Use an external Elasticsearch server
By default, an example logstash.conf will be downloaded using wget
and used in your container.
$ docker run -d \
-p 9292:9292 \
-p 9200:9200 \
pblittle/docker-logstash
To use your own config file, set the LOGSTASH_CONFIG_URL
environment variable using the -e
flag as follows:
$ docker run -d \
-e LOGSTASH_CONFIG_URL=<your_logstash_config_url> \
-p 9292:9292 \
-p 9200:9200 \
pblittle/docker-logstash
To use config files from the local file system, mount the directory as a volume using the -v
flag. Any file in /opt/logstash/conf.d
in the container will get loaded by logstash.
$ docker run -d \
-v <your_logstash_config_dir>:/opt/logstash/conf.d \
-p 9292:9292 \
-p 9200:9200 \
pblittle/docker-logstash
If you want to link to a container running Elasticsearch rather than use the embedded Elasticsearch server:
$ docker run -d \
--link <your_es_container_name>:es \
-p 9292:9292 \
pblittle/docker-logstash
To have the linked Elasticsearch container's bind_host
and port
automatically detected, you will need to set the bind_host
and port
to ES_HOST
and ES_PORT
respecively in your logstash config file. For example:
output {
elasticsearch {
bind_host => "ES_HOST"
port => "ES_PORT"
}
}
If you are using an external Elasticsearch server, simply set the ES_HOST
and ES_PORT
environment variables in your run
command:
$ docker run -d \
-e ES_HOST=<your_es_container_host> \
-e ES_PORT=<your_es_container_port> \
-p 9292:9292 \
pblittle/docker-logstash
If you prefer to build from source rather than use the pblittle/docker-logstash trusted build published to the public Docker Registry, execute the following:
$ git clone https://github.com/pblittle/docker-logstash.git
$ cd docker-logstash
If you are using Vagrant, you can build and run the container in a VM by executing:
$ vagrant up $ vagrant ssh $ cd /vagrant/1.4
From there, build and run a container using the newly created virtual machine:
$ make
You can now verify the logstash installation by visiting the Kibana dashboard:
http://<your_container_ip>:9292/index.html#/dashboard/file/logstash.json
Special shoutout to @ehazlett's excellent post, logstash and Kibana via Docker.
- Fork it
- Checkout the develop branch (
git checkout -b develop
) - Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create new Pull Request
This application is distributed under the Apache License, Version 2.0.