monolith/docker/docker-compose.prod.yml

268 lines
5.9 KiB
YAML
Raw Normal View History

2022-09-18 12:04:08 +00:00
version: "2.2"
# volumes:
# metadata_data: {}
# middle_var: {}
# historical_var: {}
# broker_var: {}
# coordinator_var: {}
# router_var: {}
# druid_shared: {}
2022-09-18 12:04:08 +00:00
services:
app:
image: pathogen/monolith:latest
2022-09-21 11:08:29 +00:00
container_name: monolith
build: ./docker
volumes:
- ${PORTAINER_GIT_DIR}:/code
env_file:
2022-09-05 06:20:30 +00:00
- ../stack.env
volumes_from:
2022-09-18 12:04:08 +00:00
- tmp
2022-09-04 20:29:00 +00:00
depends_on:
2022-09-18 12:04:08 +00:00
broker:
condition: service_started
kafka:
condition: service_healthy
tmp:
condition: service_started
redis:
condition: service_healthy
# - db
2022-09-04 20:29:00 +00:00
threshold:
image: pathogen/threshold:latest
2022-09-21 11:08:29 +00:00
container_name: threshold
build: ./legacy/docker
volumes:
- ${PORTAINER_GIT_DIR}:/code
- ${THRESHOLD_CONFIG_DIR}:/code/legacy/conf/live
#- ${THRESHOLD_TEMPLATE_DIR}:/code/conf/templates
- ${THRESHOLD_CERT_DIR}:/code/legacy/conf/cert
ports:
- "${THRESHOLD_LISTENER_PORT}:${THRESHOLD_LISTENER_PORT}"
- "${THRESHOLD_RELAY_PORT}:${THRESHOLD_RELAY_PORT}"
- "${THRESHOLD_API_PORT}:${THRESHOLD_API_PORT}"
env_file:
- ../stack.env
volumes_from:
- tmp
2022-09-18 12:04:08 +00:00
depends_on:
tmp:
condition: service_started
redis:
condition: service_healthy
2022-09-18 12:04:08 +00:00
# db:
#image: pathogen/manticore:kibana
# image: manticoresearch/manticore:latest
#build:
# context: ./docker/manticore
# args:
# DEV: 1
# restart: always
turnilo:
container_name: turnilo
image: uchhatre/turnilo:latest
2022-09-04 20:29:00 +00:00
ports:
2022-09-18 12:04:08 +00:00
- 9093:9090
2022-09-04 20:29:00 +00:00
environment:
2022-09-18 12:04:08 +00:00
- DRUID_BROKER_URL=http://broker:8082
depends_on:
- broker
metabase:
container_name: metabase
image: metabase/metabase:latest
ports:
2022-09-18 12:15:10 +00:00
- 3096:3000
2022-09-21 13:39:11 +00:00
environment:
- JAVA_OPTS=-Xmx1g
2022-09-18 12:04:08 +00:00
depends_on:
- broker
postgres:
container_name: postgres
image: postgres:latest
2022-09-04 20:29:00 +00:00
volumes:
- /block/store/metadata_data:/var/lib/postgresql/data
2022-09-18 12:04:08 +00:00
environment:
- POSTGRES_PASSWORD=FoolishPassword
- POSTGRES_USER=druid
- POSTGRES_DB=druid
2022-09-05 06:20:30 +00:00
2022-09-18 12:04:08 +00:00
# Need 3.5 or later for container nodes
zookeeper:
container_name: zookeeper
image: zookeeper:3.5
ports:
- "2181:2181"
environment:
- ZOO_MY_ID=1
kafka:
image: wurstmeister/kafka:latest
2022-09-21 11:08:29 +00:00
container_name: kafka
2022-09-18 12:04:08 +00:00
depends_on:
- zookeeper
ports:
- 9092:9092
- 29092:29092
2022-09-18 12:04:08 +00:00
environment:
KAFKA_BROKER_ID: 1
KAFKA_ZOOKEEPER_CONNECT: zookeeper:2181
KAFKA_ADVERTISED_LISTENERS: PLAINTEXT://kafka:9092,PLAINTEXT_HOST://localhost:29092
KAFKA_LISTENERS: PLAINTEXT://kafka:9092,PLAINTEXT_HOST://localhost:29092
KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: PLAINTEXT:PLAINTEXT,PLAINTEXT_HOST:PLAINTEXT
2022-09-18 12:04:08 +00:00
KAFKA_INTER_BROKER_LISTENER_NAME: PLAINTEXT
KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1
KAFKA_AUTO_CREATE_TOPICS_ENABLE: 'true'
KAFKA_MESSAGE_MAX_BYTES: 2000000
#KAFKA_HEAP_OPTS: -Xmx2g
2022-09-18 12:04:08 +00:00
healthcheck:
test: ["CMD", "kafka-topics.sh", "--list", "--bootstrap-server", "kafka:9092"]
start_period: 15s
interval: 30s
timeout: 30s
2022-09-19 09:48:29 +00:00
retries: 45
2022-09-18 12:04:08 +00:00
coordinator:
image: apache/druid:0.23.0
container_name: coordinator
volumes:
- /block/store/druid_shared:/opt/shared
- /block/store/coordinator_var:/opt/druid/var
2022-09-18 12:04:08 +00:00
depends_on:
- zookeeper
- postgres
ports:
- "8081:8081"
command:
- coordinator
env_file:
- environment
broker:
image: apache/druid:0.23.0
container_name: broker
volumes:
- /block/store/broker_var:/opt/druid/var
2022-09-18 12:04:08 +00:00
depends_on:
- zookeeper
- postgres
- coordinator
ports:
- "8082:8082"
command:
- broker
env_file:
- environment
historical:
image: apache/druid:0.23.0
container_name: historical
volumes:
- /block/store/druid_shared:/opt/shared
- /block/store/historical_var:/opt/druid/var
2022-09-18 12:04:08 +00:00
depends_on:
- zookeeper
- postgres
- coordinator
ports:
- "8083:8083"
command:
- historical
env_file:
- environment
middlemanager:
image: apache/druid:0.23.0
container_name: middlemanager
volumes:
- /block/store/druid_shared:/opt/shared
- /block/store/middle_var:/opt/druid/var
2022-09-18 12:04:08 +00:00
depends_on:
- zookeeper
- postgres
- coordinator
ports:
- "8091:8091"
- "8100-8105:8100-8105"
command:
- middleManager
env_file:
- environment
router:
image: apache/druid:0.23.0
container_name: router
volumes:
- /block/store/router_var:/opt/druid/var
2022-09-18 12:04:08 +00:00
depends_on:
- zookeeper
- postgres
- coordinator
ports:
- "8888:8888"
command:
- router
env_file:
- environment
# db:
# #image: pathogen/manticore:kibana
# image: manticoresearch/manticore:dev
# #build:
# # context: ./docker/manticore
# # args:
# # DEV: 1
# restart: always
# ports:
# - 9308
# - 9312
# - 9306
# ulimits:
# nproc: 65535
# nofile:
# soft: 65535
# hard: 65535
# memlock:
# soft: -1
# hard: -1
# environment:
# - MCL=1
# volumes:
# - ./docker/data:/var/lib/manticore
# - ./docker/manticore.conf:/etc/manticoresearch/manticore.conf
tmp:
image: busybox
command: chmod -R 777 /var/run/redis
2022-09-18 12:04:08 +00:00
volumes:
- /var/run/redis
redis:
image: redis
command: redis-server /etc/redis.conf
2022-09-07 06:20:30 +00:00
ulimits:
nproc: 65535
nofile:
soft: 65535
hard: 65535
volumes:
2022-09-18 12:04:08 +00:00
- ${PORTAINER_GIT_DIR}/docker/redis.conf:/etc/redis.conf
volumes_from:
- tmp
healthcheck:
test: "redis-cli -s /var/run/redis/redis.sock ping"
interval: 2s
timeout: 2s
retries: 15
networks:
default:
external:
name: pathogen