-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDockerfile
More file actions
101 lines (78 loc) · 3.62 KB
/
Dockerfile
File metadata and controls
101 lines (78 loc) · 3.62 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
# Dockerfile for ELK stack on Ubuntu base
# Help:
# Default command: docker run -d -p 80:80 -p 3333:3333 -p 3334:3334 -p 9200:9200 elk
# Default command will start ELK within a docker
# To send data to elk, stream to TCP port 3333
# Example: echo 'Hello ELK ' | nc HOST 3333. Host is the IP of the docker host
# To login to bash: docker exec -it elk bash
FROM ubuntu
MAINTAINER Leo Rowe
# Initial update
RUN apt-get update
# This is to install add-apt-repository utility. All commands have to be non interactive with -y option
RUN DEBIAN_FRONTEND=noninteractive apt-get install -y software-properties-common
# Install Oracle Java 8, accept license command is required for non interactive mode
RUN apt-key adv --keyserver keyserver.ubuntu.com --recv-keys EEA14886 && \
DEBIAN_FRONTEND=noninteractive add-apt-repository -y ppa:webupd8team/java && \
apt-get update && \
echo oracle-java8-installer shared/accepted-oracle-license-v1-1 select true | sudo /usr/bin/debconf-set-selections &&\
DEBIAN_FRONTEND=noninteractive apt-get install -y oracle-java8-installer
# Elasticsearch installation
# Start Elasticsearch by /elasticsearch/bin/elasticsearch. This will run on port 9200.
RUN wget https://download.elasticsearch.org/elasticsearch/elasticsearch/elasticsearch-1.3.1.tar.gz && \
tar xf elasticsearch-1.3.1.tar.gz && \
rm elasticsearch-1.3.1.tar.gz && \
mv elasticsearch-1.3.1 elasticsearch
# Logstash installation
# Create a logstash.conf and start logstash by /logstash/bin/logstash agent -f logstash.conf
RUN wget https://download.elasticsearch.org/logstash/logstash/logstash-1.4.2.tar.gz && \
tar xf logstash-1.4.2.tar.gz && \
rm logstash-1.4.2.tar.gz && \
mv logstash-1.4.2 logstash
# Kibana installation
RUN wget https://download.elasticsearch.org/kibana/kibana/kibana-3.1.0.tar.gz && \
tar xf kibana-3.1.0.tar.gz && \
rm kibana-3.1.0.tar.gz && \
mv kibana-3.1.0 kibana
# Install curl utility just for testing
RUN apt-get update && \
apt-get install -y curl
# Install vim for editing config file
RUN apt-get install -y vim
# Install Nginx
# Start or stop with /etc/init.d/nginx start/stop. Runs on port 80.
# Sed command is to make the worker threads of nginx run as user root
RUN apt-get update && \
DEBIAN_FRONTEND=noninteractive apt-get install -y nginx && \
sed -i -e 's/www-data/root/g' /etc/nginx/nginx.conf
# Deploy kibana to Nginx
RUN mv /usr/share/nginx/html /usr/share/nginx/html_orig && \
mkdir /usr/share/nginx/html && \
cp -r /kibana/* /usr/share/nginx/html
# Create a start bash script
RUN touch elk_start.sh && \
echo '#!/bin/bash' >> elk_start.sh && \
echo '/elasticsearch/bin/elasticsearch &' >> elk_start.sh && \
echo '/etc/init.d/nginx start &' >> elk_start.sh && \
echo 'exec /logstash/bin/logstash agent -f /logstash.conf &' >> elk_start.sh && \
echo 'tail -f ' >> elk_start.sh && \
chmod 777 elk_start.sh
#Download shaksperea playbook
ADD shakespeare.json /shakespeare.json
# Add init shakespeare playbook shell script in elasticsearch
ADD build.sh /build.sh
# Add remove shakespeare playbook shell script in elasticsearch
ADD remove.sh /remove.sh
#Add add sample apache log into images
ADD access.log /access.log
#Add add logstash.conf into images
ADD logstash.conf /logstash.conf
#Add restart-logstash.sh into images
RUN touch restart-logstash.sh && \
echo "ps aux | grep -i logstash | awk {'print \$2'} | xargs kill -9" >> restart-logstash.sh && \
echo 'exec /logstash/bin/logstash agent -f /logstash.conf &' >> restart-logstash.sh && \
chmod 777 restart-logstash.sh
# 80=nginx, 9200=elasticsearch, 3333,3334=logstash tcp input
EXPOSE 80 3333 3334 9200 49021
# Run the ELK boot up command
CMD /elk_start.sh