-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdocker-compose.yml
124 lines (116 loc) · 2.77 KB
/
docker-compose.yml
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
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
version: '3.4'
services:
zookeeper:
build:
context: zookeeper/
args:
ZOOKEEPER_VERSION: 3.4.6
ports:
- 2181:2181
networks:
- demo
# uncomment to force storage to your docker host machine
# volumes:
# - ./data/zookeeper:/opt/zookeeper/data
healthcheck:
test: ["CMD", "/opt/zookeeper/zkServer.sh", "status"]
interval: 5s
timeout: 5s
retries: 3
kafka:
build:
context: kafka/
args:
KAFKA_VERSION: 0.10.0.0
ports:
- 9092:9092
networks:
- demo
# uncomment to force storage to your docker host machine
# volumes:
# - ./data/kafka/:/kafka/
# - ./kafka/server.properties/:/opt/kafka_2.11-0.10.0.0/config/server.properties:ro
environment:
KAFKA_PORT: 9092
KAFKA_DELETE_TOPIC_ENABLE: "true"
KAFKA_BROKER_ID: 0
KAFKA_ADVERTISED_PORT: 9092
KAFKA_ADVERTISED_HOST_NAME: "${DOCKERHOST}"
KAFKA_ADVERTISED_LISTENERS: "PLAINTEXT://${DOCKERHOST}:9092"
KAFKA_ZOOKEEPER_CONNECT: "${DOCKERHOST}:2181"
KAFKA_CREATE_TOPICS: "OsQueryD:1:1,:1:1"
KAFKA_LOG_DIRS: /kafka/logs
depends_on:
- zookeeper
healthcheck:
test: ["CMD-SHELL", "/bin/healthcheck.sh"]
interval: 5s
timeout: 10s
retries: 5
logstash:
build:
context: logstash/
args:
ELK_VERSION: 6.4.2
volumes:
- ./logstash/config/logstash.yml:/usr/share/logstash/config/logstash.yml:ro
- ./logstash/pipeline:/usr/share/logstash/pipeline:ro
ports:
- "5000:5000"
- "9600:9600"
networks:
- demo
environment:
LS_JAVA_OPTS: "-Xmx256m -Xms256m"
depends_on:
- elasticsearch
- kafka
elasticsearch:
build:
context: elasticsearch/
args:
ELK_VERSION: 6.4.2
volumes:
- ./elasticsearch/config/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml:ro
ports:
- "9200:9200"
- "9300:9300"
networks:
- demo
environment:
ES_JAVA_OPTS: "-Xmx256m -Xms256m"
healthcheck:
test: ["CMD-SHELL", "curl --silent --fail localhost:9200/_cluster/health || exit 1"]
interval: 30s
timeout: 30s
retries: 3
kibana:
build:
context: kibana/
args:
ELK_VERSION: 6.4.2
volumes:
- ./kibana/config/:/usr/share/kibana/config:ro
ports:
- "5601:5601"
networks:
- demo
depends_on:
- elasticsearch
healthcheck:
test: ["CMD-SHELL", "curl --silent --fail localhost:5601 || exit 1"]
interval: 30s
timeout: 30s
retries: 3
osqueryd:
build:
context: osqueryd/
volumes:
- ./osqueryd/osquery.example.conf:/etc/osquery/osquery.conf:ro
networks:
- demo
depends_on:
- kibana
networks:
demo:
driver: bridge