-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
60 lines (58 loc) · 2.08 KB
/
Copy pathdocker-compose.yml
File metadata and controls
60 lines (58 loc) · 2.08 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
version: '3.8'
services:
redis:
image: redis:latest
container_name: passimx-redis
command: redis-server --appendonly yes --port ${REDIS_PORT}
expose:
- ${REDIS_PORT}
ports:
- ${REDIS_PORT}:${REDIS_PORT}
networks:
- main
volumes:
- ./data/data_redis:/data
kafka: # Если подключение будет с локальной машины - то поменять localhost:9094 -> kafka:9094
image: 'bitnami/kafka:latest'
container_name: passimx-kafka
restart: always
networks:
- main
env_file: .env
environment:
- KAFKA_ENABLE_KRAFT=yes
- KAFKA_BROKER_ID=1
- KAFKA_CFG_NODE_ID=1
- KAFKA_CFG_PROCESS_ROLES=broker,controller
- KAFKA_CFG_LISTENERS=CLIENT://:${KAFKA_CLIENT_PORT},INTERNAL://:${KAFKA_INTERNAL_PORT},EXTERNAL://:${KAFKA_EXTERNAL_PORT},
- KAFKA_CFG_LISTENER_SECURITY_PROTOCOL_MAP=INTERNAL:PLAINTEXT,CLIENT:SASL_PLAINTEXT,EXTERNAL:SASL_PLAINTEXT
- KAFKA_CFG_ADVERTISED_LISTENERS=CLIENT://kafka:${KAFKA_CLIENT_PORT},EXTERNAL://kafka:${KAFKA_EXTERNAL_PORT}
- KAFKA_CFG_INTER_BROKER_LISTENER_NAME=CLIENT
- KAFKA_CFG_SASL_MECHANISM_INTER_BROKER_PROTOCOL=PLAIN
- KAFKA_CFG_SASL_ENABLED_MECHANISMS=PLAIN
- KAFKA_CLIENT_USERS=${KAFKA_CLIENT_USERS}
- KAFKA_CLIENT_PASSWORDS=${KAFKA_USER_PASSWORD}
- KAFKA_CFG_CONTROLLER_LISTENER_NAMES=INTERNAL
- KAFKA_CFG_CONTROLLER_QUORUM_VOTERS=1@127.0.0.1:9093
- ALLOW_PLAINTEXT_LISTENER=yes
ports:
- ${KAFKA_CLIENT_PORT}:${KAFKA_CLIENT_PORT}
- ${KAFKA_EXTERNAL_PORT}:${KAFKA_EXTERNAL_PORT}
command:
- bash
- -c
- |
(
IFS="," read -ra TOPICS <<< "$$PRE_CREATE_TOPICS";
for T in "$${TOPICS[@]}"; do
/opt/bitnami/kafka/bin/kafka-topics.sh \
--bootstrap-server localhost:9094 \
--create --topic "$$T" --if-not-exists &&
echo "Created $$T" ||
echo "Failed to create $$T";
done;
) & /opt/bitnami/scripts/kafka/run.sh
networks:
main:
driver: bridge
name: main