-
Notifications
You must be signed in to change notification settings - Fork 48
/
docker-compose.yml
155 lines (141 loc) · 3.47 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
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
version: '3'
services:
zookeeper:
image: "confluentinc/cp-zookeeper:5.2.1"
environment:
ZOOKEEPER_CLIENT_PORT: 2181
ZOOKEEPER_TICK_TIME: 2000
ZOOKEEPER_SYNC_LIMIT: 2
mysql:
image: mysql
container_name: mysql
environment:
MYSQL_ROOT_PASSWORD: root
MYSQL_DATABASE: transacao
ports:
- 3306:3306
#do lado esquerdo dos : tem a porta do pc, e do lado direto do container
volumes:
- transacao_volume:/var/lib/mysql
kafka:
image: "confluentinc/cp-kafka:5.2.1"
ports:
- 9092:9092
depends_on:
- zookeeper
environment:
KAFKA_BROKER_ID: 1
KAFKA_ZOOKEEPER_CONNECT: "zookeeper:2181"
KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: PLAINTEXT:PLAINTEXT,PLAINTEXT_HOST:PLAINTEXT
KAFKA_ADVERTISED_LISTENERS: PLAINTEXT://kafka:29092,PLAINTEXT_HOST://localhost:9092
KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: "1"
KAFKA_AUTO_CREATE_TOPICS_ENABLE: "true"
postgres:
image: 'postgres:alpine'
volumes:
- postgres-volume:/var/lib/postgresql/data
ports:
- 5432:5432
environment:
POSTGRES_USER: keycloak
POSTGRES_PASSWORD: password
POSTGRES_DB: keycloak
POSTGRES_HOST: postgres
keycloak:
image: jboss/keycloak
ports:
- 18443:8443
- 18080:8080
- 19990:9990
depends_on:
# Just a delay to wait for postgres! This is not recommended!
- grafana
- prometheus
- jaeger
- kafka
- zookeeper
- contas
- analise
- transacoes
- postgres
environment:
DB_VENDOR: postgres
DB_ADDR: postgres
DB_PORT: 5432
DB_DATABASE: keycloak
DB_USER: keycloak
DB_PASSWORD: password
KEYCLOAK_USER: admin
KEYCLOAK_PASSWORD: Pa55w0rd
POSTGRES_PORT_5432_TCP_ADDR: 127.0.0.1
analise:
image: 'zupacademy/analise-financeira'
ports:
- 9999:9999
environment:
SERVER_PORT: 9999
LOG_LEVEL: INFO
URL_SISTEMA_CARTAO: http://contas:8888/api/cartoes
JAEGER_ENDPOINT: http://jaeger:14268/api/traces
contas:
image: 'zupacademy/contas'
ports:
- 8888:8888
environment:
SERVER_PORT: 8888
LOG_LEVEL: INFO
JAEGER_ENDPOINT: http://jaeger:14268/api/traces
transacoes:
image: 'zupacademy/transacoes'
ports:
- 7777:7777
depends_on:
- kafka
environment:
SERVER_PORT: 7777
LOG_LEVEL: INFO
KAFKA_HOST: "kafka:29092"
JAEGER_ENDPOINT: http://jaeger:14268/api/traces
TRANSACTION_DELAY: 60000 #tempo em milisegundos
jaeger:
image: jaegertracing/all-in-one
ports:
- 5775:5775/udp
- 6831:6831/udp
- 6832:6832/udp
- 5778:5778
- 16686:16686
- 14268:14268
- 14250:14250
- 9411:9411
environment:
COLLECTOR_ZIPKIN_HTTP_PORT: 9411
prometheus:
image: prom/prometheus
volumes:
- prometheus-volume:/etc/prometheus/
network_mode: bridge
ports:
- "9090:9090"
grafana:
image: grafana/grafana
volumes:
- grafana-volume:/var/lib/grafana
network_mode: bridge
ports:
- "3000:3000"
depends_on:
- prometheus
vault:
image: vault:1.5.3
ports:
- 8200:8200
environment:
VAULT_DEV_ROOT_TOKEN_ID: ee413645-dbe8-4848-afc6-6bb2768ada75
VAULT_TOKEN: ee413645-dbe8-4848-afc6-6bb2768ada75
VAULT_ADDR: http://127.0.0.1:8200
volumes:
grafana-volume:
prometheus-volume:
postgres-volume:
transacao_volume: