-
Notifications
You must be signed in to change notification settings - Fork 0
/
docker-compose.dev.yaml
146 lines (134 loc) · 3.47 KB
/
docker-compose.dev.yaml
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
version: "3.9"
services:
zookeeper:
image: confluentinc/cp-zookeeper:latest
container_name: monitor_zookeeper
restart: always
environment:
- ZOOKEEPER_CLIENT_PORT=2181
- ZOOKEEPER_TICK_TIME=2000
volumes:
- monitor_zookeeper:/var/lib/zookeeper/data/
kafka:
image: confluentinc/cp-kafka:latest
container_name: monitor_kafka
restart: always
depends_on:
- zookeeper
ports:
- "9092:9092"
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://kafka:9092
- KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR=1
- KAFKA_TRANSACTION_STATE_LOG_MIN_ISR=1
- KAFKA_TRANSACTION_STATE_LOG_REPLICATION_FACTOR=1
- KAFKA_GROUP_INITIAL_REBALANCE_DELAY_MS=0
- KAFKA_JMX_PORT=9101
- KAFKA_JMX_HOSTNAME=kafka
volumes:
- monitor_kafka:/var/lib/kafka/data/
postgres:
image: postgres:latest
container_name: monitor_postgres
restart: always
ports:
- "5432:5432"
environment:
- POSTGRES_USER=admin
- POSTGRES_PASSWORD=1
- POSTGRES_DB=monitoring
volumes:
- monitor_postgres:/var/lib/postgresql/data/
pgadmin:
image: dpage/pgadmin4:latest
container_name: monitor_pgadmin
restart: always
ports:
- "15432:80"
env_file: .env
volumes:
- monitor_pgadmin:/var/lib/pgadmin/
redis:
image: redis:latest
container_name: monitor_redis
restart: always
ports:
- "6379:6379"
volumes:
- type: bind
source: ./conf.d/redis/redis.conf
target: /usr/local/etc/redis/redis.conf
read_only: true
- monitor_redis:/data/
command:
- redis-server
- /usr/local/etc/redis/redis.conf
redis-commander:
container_name: monitor_redis-commander
image: rediscommander/redis-commander:latest
restart: always
ports:
- "8081:8081"
portainer:
image: portainer/portainer:latest
container_name: monitor_portainer
restart: always
ports:
- "9000:9000"
volumes:
- /var/run/docker.sock:/var/run/docker.sock
- monitor_portainer:/data/
flower:
image: mher/flower
container_name: monitor_flower
restart: always
ports:
- "8888:8888"
env_file: .env
command: ["celery", "flower", "--port=8888"]
celery:
build: .
image: monitor_app
container_name: monitor_celery
restart: always
env_file: .env
volumes:
- ./src/:/usr/src/app/
- ./conf.d/kafka_ssl/:/usr/src/conf.d/kafka_ssl/
command: ["celery", "worker", "-c", "1"]
celerybeat:
image: monitor_app
container_name: monitor_celerybeat
restart: always
env_file: .env
volumes:
- ./src/:/usr/src/app/
- ./conf.d/kafka_ssl/:/usr/src/conf.d/kafka_ssl/
command: ["celery", "-A", "tasks", "beat"]
depends_on:
- celery
transporter:
image: monitor_app
container_name: monitor_transporter
restart: always
env_file: .env
volumes:
- ./src/:/usr/src/app/
- ./conf.d/kafka_ssl/:/usr/src/conf.d/kafka_ssl/
command: ["python", "data_transfer.py"]
volumes:
monitor_kafka:
external: true
monitor_zookeeper:
external: true
monitor_postgres:
external: true
monitor_pgadmin:
external: true
monitor_redis:
external: true
monitor_portainer:
external: true