generated from yandex-praktikum/java-shareit
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
97 lines (87 loc) · 2.44 KB
/
docker-compose.yml
File metadata and controls
97 lines (87 loc) · 2.44 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
version: '3.9'
services:
gateway:
build: gateway
container_name: gateway
ports:
- '8080:8080'
depends_on:
- db
- server
- zookeeper
environment:
- SHAREIT_SERVER_URL=http://server:9090
- SPRING_SECURITY_OAUTH2_RESOURCESERVER_JWT_JWK_SET_URI=http://auth:8180/realms/shareit-realm/protocol/openid-connect/certs
server:
build: server
container_name: server
ports:
- '9090:9090'
depends_on:
auth:
condition: service_healthy
environment:
- SPRING_DATASOURCE_URL=jdbc:postgresql://db:5432/shareit
- KEYCLOAK_AUTH_SERVER_URL=http://auth:8180
- SPRING_SECURITY_OAUTH2_RESOURCESERVER_JWT_JWK_SET_URI=http://auth:8180/realms/shareit-realm/protocol/openid-connect/certs
db:
image: postgres:13.7-alpine
container_name: db
ports:
- '6541:5432'
environment:
- POSTGRES_DB=shareit
- POSTGRES_USER=sharer
- POSTGRES_PASSWORD=Ilikeshare
depends_on:
- broker
auth:
container_name: auth
image: quay.io/keycloak/keycloak:20.0.1
volumes:
- ./import:/opt/keycloak/data/import
command:
- start-dev
- --http-port=8180
- --hostname-url=http://localhost:8180
- --import-realm
# export realms with users -> kc.bat export --dir .\ --users realm_file
healthcheck:
test: ["CMD-SHELL", "curl http://localhost:8180/auth/realms/shareit-realm"]
interval: 30s
timeout: 10s
retries: 20
start_period: 20s
depends_on:
- broker
environment:
- KEYCLOAK_ADMIN=admin
- KEYCLOAK_ADMIN_PASSWORD=admin
ports:
- '8180:8180'
zookeeper:
container_name: zookeeper
image: confluentinc/cp-zookeeper:latest
environment:
ZOOKEEPER_CLIENT_PORT: 2181
ZOOKEEPER_TICK_TIME: 2000
ports:
- '22181:2181'
broker:
image: confluentinc/cp-kafka:latest
hostname: broker
container_name: broker
user: "0:0"
depends_on:
- zookeeper
ports:
- '9092:9092'
environment:
KAFKA_BROKER_ID: 1
KAFKA_ZOOKEEPER_CONNECT: zookeeper:2181
KAFKA_ADVERTISED_LISTENERS: PLAINTEXT://broker:29092,PLAINTEXT_HOST://localhost:9092
KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: PLAINTEXT:PLAINTEXT,PLAINTEXT_HOST:PLAINTEXT
KAFKA_INTER_BROKER_LISTENER_NAME: PLAINTEXT
KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1
volumes:
- ./broker/data:/var/lib/kafka/data