-
Notifications
You must be signed in to change notification settings - Fork 0
/
docker-compose.yml
121 lines (109 loc) · 2.9 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
version: "3.8"
services:
elasticsearch:
image: docker.elastic.co/elasticsearch/elasticsearch-oss:7.9.3
container_name: elasticsearch
restart: unless-stopped
ports:
- "9200:9200"
- "9300:9300"
environment:
cluster.name: elasticsearch-cluster
discovery.type: single-node
bootstrap.memory_lock: "true"
network.bind_host: 0.0.0.0
transport.host: 127.0.0.1
network.host: 0.0.0.0
ES_JAVA_OPTS: "-Xms512m -Xmx512m"
ulimits:
memlock:
soft: -1
hard: -1
healthcheck:
test: "curl -f http://localhost:9200 || exit 1"
start_period: 30s
logstash:
image: docker.elastic.co/logstash/logstash:7.9.3
container_name: logstash
restart: unless-stopped
ports:
- "5044:5044"
volumes:
- ./config/logstash/pipeline:/usr/share/logstash/pipeline/
depends_on:
- elasticsearch
healthcheck:
test: "curl -f http://localhost:9600 || exit 1"
start_period: 30s
filebeat:
build: config/filebeat
container_name: filebeat
restart: unless-stopped
volumes:
# necessario para acessar todos os logs dockers
- /var/lib/docker/containers:/usr/share/dockerlogs/data:ro
# necessario para acessar informações adicionais do container
- /var/run/docker.sock:/var/run/docker.sock
depends_on:
- elasticsearch
- logstash
kibana:
image: docker.elastic.co/kibana/kibana-oss:7.9.3
container_name: kibana
restart: unless-stopped
ports:
- "5601:5601"
environment:
ELASTICSEARCH_URL: http://elasticsearch:9200
healthcheck:
test: "curl -f http://localhost:5601 || exit 1"
start_period: 30s
depends_on:
- elasticsearch
- filebeat
- logstash
prometheus:
image: prom/prometheus:v2.23.0
container_name: prometheus
restart: unless-stopped
volumes:
- ./config/prometheus/prometheus.yml:/etc/prometheus/prometheus.yml
ports:
- 9090:9090
healthcheck:
test: [ "CMD", "nc", "-z", "localhost", "9090" ]
start_period: 30s
grafana:
image: grafana/grafana:7.3.5
container_name: grafana
restart: unless-stopped
ports:
- 3000:3000
environment:
- GF_USERS_ALLOW_SIGN_UP=false
volumes:
- ./config/grafana/provisioning:/etc/grafana/provisioning
depends_on:
- prometheus
healthcheck:
test: [ "CMD", "nc", "-z", "localhost", "3000" ]
start_period: 30s
spring-elasticsearch:
build: customer-api
ports:
- 8080:8080
expose:
- "8080"
environment:
- SPRING_PROFILES_ACTIVE=docker
- spring.data.rest.uris=elasticsearch:9200
- start-up-data:false
healthcheck:
test: ["CMD","http://localhost:8080/"]
depends_on:
- elasticsearch
restart: on-failure:5
links:
- elasticsearch:elasticsearch
networks:
spring-elasticsearch-network: