-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
48 lines (42 loc) · 1.51 KB
/
docker-compose.yml
File metadata and controls
48 lines (42 loc) · 1.51 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
version: '3.8'
services:
kafka:
image: confluentinc/cp-kafka:7.5.1 # Apache Kafka 3.5.x = Confluent Platform 7.5.x
container_name: kafka
ports:
- "9092:9092"
environment:
# KRaft 필수 설정
KAFKA_NODE_ID: 1 # 브로커 노드 ID
CLUSTER_ID: 'EpwKlK0lR6qKZW0cGwZz8w' # 클러스터 고유 식별자
# 리스너 설정
KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: 'CONTROLLER:PLAINTEXT,PLAINTEXT:PLAINTEXT'
KAFKA_LISTENERS: 'PLAINTEXT://:9092,CONTROLLER://:9093'
KAFKA_ADVERTISED_LISTENERS: 'PLAINTEXT://localhost:9092' # order-service가 접근 가능하도록 설정
# KRaft 모드 설정
KAFKA_PROCESS_ROLES: 'broker,controller' # 브로커와 컨트롤러 역할 통합
KAFKA_CONTROLLER_QUORUM_VOTERS: '1@localhost:9093' # 컨트롤러 쿼럼 설정
KAFKA_CONTROLLER_LISTENER_NAMES: 'CONTROLLER' # 컨트롤러 통신용 리스너
# 복제 관련 설정
KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1
KAFKA_TRANSACTION_STATE_LOG_MIN_ISR: 1
KAFKA_TRANSACTION_STATE_LOG_REPLICATION_FACTOR: 1
volumes:
- ./data/kafka:/var/lib/kafka/data
networks:
- order_network
kafka-ui:
image: provectuslabs/kafka-ui:latest
container_name: kafka-ui
ports:
- "9090:8080" # Kafka UI 포트
environment:
- KAFKA_CLUSTERS_0_NAME=local
- KAFKA_CLUSTERS_0_BOOTSTRAPSERVERS=kafka:9092
networks:
- order_network
depends_on:
- kafka
networks:
order_network:
driver: bridge