-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathdocker-compose-local.yaml
More file actions
136 lines (127 loc) · 3.56 KB
/
Copy pathdocker-compose-local.yaml
File metadata and controls
136 lines (127 loc) · 3.56 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
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
version: '3.8'
services:
# 1. Spring Boot 애플리케이션 (추가된 부분)
backend:
container_name: devnogi-community-server
build:
context: .
dockerfile: Dockerfile
ports:
- "8093:8093"
tty: true
stdin_open: true
environment:
# JVM 설정
- JAVA_TOOL_OPTIONS=-Xms256m -Xmx512m
- SPRING_PROFILES_ACTIVE=local
- MINIO_URL=http://minio:9000
- MINIO_BUCKET=dcs-local-bucket
# application.yml 변수 매핑
- DB_HOST=mysql
- DB_PORT=3306
- DB_SCHEMA=${DB_SCHEMA}
- DB_USER=${DB_USER:-root}
- DB_PASSWORD=${DB_PASSWORD}
- REDIS_PORT=6379
- REDIS_HOST=redis
- KAFKA_BOOTSTRAP_SERVERS=kafka:29092
- KAFKA_CONSUMER_GROUP_ID=devnogi-community-group
- JWT_SECRET_KEY=${JWT_SECRET_KEY}
depends_on:
mysql:
condition: service_healthy
redis:
condition: service_healthy
minio:
condition: service_healthy
networks:
- my-network
restart: always
redis:
image: redis:latest
container_name: devnogi-community-redis
restart: unless-stopped
ports:
- "${REDIS_PORT:-6379}:6379"
networks:
- my-network
volumes:
- ./data/redis:/data
healthcheck:
test: [ "CMD", "redis-cli", "ping" ]
interval: 5s
timeout: 3s
retries: 5
mysql:
image: mysql:8.0
container_name: devnogi-community-mysql
restart: unless-stopped
ports:
- "3319:3306"
environment:
MYSQL_ROOT_PASSWORD: ${DB_ROOT_PASSWORD}
MYSQL_DATABASE: ${DB_SCHEMA}
MYSQL_USER: ${DB_USER:-root}
MYSQL_PASSWORD: ${DB_PASSWORD}
LANG: C.UTF_8
TZ: Asia/Seoul
volumes:
- ./data/mysql:/var/lib/mysql
networks:
- my-network
command:
- --character-set-server=utf8mb4
- --collation-server=utf8mb4_0900_ai_ci
- --default-time-zone=+09:00
healthcheck:
test: [ "CMD", "mysqladmin", "ping", "-h", "localhost" ]
interval: 10s
timeout: 5s
retries: 5
minio:
image: minio/minio:latest
container_name: minio-local
ports:
- "9000:9000"
- "9001:9001"
environment:
MINIO_ROOT_USER: "minioadmin"
MINIO_ROOT_PASSWORD: "minioadmin"
volumes:
- ./local-minio-data:/data
command: server /data --console-address ":9001"
networks:
- my-network
healthcheck:
test: [ "CMD", "curl", "-f", "http://localhost:9000/minio/health/live" ]
interval: 5s
timeout: 3s
retries: 5
kafka:
image: confluentinc/cp-kafka:7.6.0
container_name: devnogi-community-kafka
ports:
- "9092:9092"
environment:
KAFKA_NODE_ID: 1
KAFKA_PROCESS_ROLES: broker,controller
KAFKA_BROKER: kafka:29092
KAFKA_LISTENERS: PLAINTEXT://0.0.0.0:29092,CONTROLLER://0.0.0.0:29093,PLAINTEXT_HOST://0.0.0.0:9092
KAFKA_ADVERTISED_LISTENERS: PLAINTEXT://kafka:29092,PLAINTEXT_HOST://localhost:9092
KAFKA_CONTROLLER_LISTENER_NAMES: CONTROLLER
KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: CONTROLLER:PLAINTEXT,PLAINTEXT:PLAINTEXT,PLAINTEXT_HOST:PLAINTEXT
KAFKA_CONTROLLER_QUORUM_VOTERS: 1@kafka:29093
KAFKA_INTER_BROKER_LISTENER_NAME: PLAINTEXT
KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1
KAFKA_GROUP_INITIAL_REBALANCE_DELAY_MS: 0
CLUSTER_ID: MkU3OEVBNTcwNTJENDM2Qk
networks:
- my-network
healthcheck:
test: [ "CMD", "kafka-topics", "--bootstrap-server", "localhost:9092", "--list" ]
interval: 10s
timeout: 5s
retries: 5
networks:
my-network:
driver: bridge