The PHP container user needs the docker group to read the socket. Uses DOCKER_GID env var in dev (defaults to 989) and dynamic GID detection via Ansible stat in prod. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
151 lines
3.5 KiB
Django/Jinja
151 lines
3.5 KiB
Django/Jinja
name: e-ticket
|
|
|
|
services:
|
|
php:
|
|
build:
|
|
context: ./docker/php/prod
|
|
dockerfile: Dockerfile
|
|
deploy:
|
|
replicas: 2
|
|
restart: unless-stopped
|
|
group_add:
|
|
- "{{ docker_gid }}"
|
|
volumes:
|
|
- .:/app
|
|
- /var/run/docker.sock:/var/run/docker.sock:ro
|
|
ports:
|
|
- "4578-4579:9000"
|
|
networks:
|
|
- e-ticket
|
|
depends_on:
|
|
pgbouncer:
|
|
condition: service_healthy
|
|
redis:
|
|
condition: service_healthy
|
|
|
|
db-master:
|
|
image: postgres:16-alpine
|
|
restart: unless-stopped
|
|
environment:
|
|
POSTGRES_USER: e-ticket
|
|
POSTGRES_PASSWORD: {{ db_password }}
|
|
POSTGRES_DB: e-ticket
|
|
command:
|
|
- postgres
|
|
- -c
|
|
- wal_level=replica
|
|
- -c
|
|
- max_wal_senders=3
|
|
- -c
|
|
- wal_keep_size=64MB
|
|
- -c
|
|
- hot_standby=on
|
|
volumes:
|
|
- db-master-data:/var/lib/postgresql/data
|
|
- ./docker/pgsql/init-master.sh:/docker-entrypoint-initdb.d/init-master.sh
|
|
networks:
|
|
- e-ticket
|
|
healthcheck:
|
|
test: ["CMD-SHELL", "pg_isready -U e-ticket -d e-ticket"]
|
|
interval: 5s
|
|
timeout: 5s
|
|
retries: 5
|
|
|
|
db-slave:
|
|
image: postgres:16-alpine
|
|
restart: unless-stopped
|
|
environment:
|
|
POSTGRES_USER: e-ticket
|
|
POSTGRES_PASSWORD: {{ db_password }}
|
|
POSTGRES_DB: e-ticket
|
|
PGDATA: /var/lib/postgresql/data
|
|
volumes:
|
|
- db-slave-data:/var/lib/postgresql/data
|
|
- ./docker/pgsql/init-slave.sh:/init-slave.sh
|
|
entrypoint: ["/bin/bash", "/init-slave.sh"]
|
|
command: ["postgres"]
|
|
networks:
|
|
- e-ticket
|
|
depends_on:
|
|
db-master:
|
|
condition: service_healthy
|
|
healthcheck:
|
|
test: ["CMD-SHELL", "pg_isready -U e-ticket -d e-ticket"]
|
|
interval: 5s
|
|
timeout: 5s
|
|
retries: 5
|
|
|
|
pgbouncer:
|
|
image: edoburu/pgbouncer
|
|
restart: unless-stopped
|
|
volumes:
|
|
- ./docker/pgsql/pgbouncer.ini:/etc/pgbouncer/pgbouncer.ini:ro
|
|
- ./docker/pgsql/userlist.txt:/etc/pgbouncer/userlist.txt:ro
|
|
networks:
|
|
- e-ticket
|
|
depends_on:
|
|
db-master:
|
|
condition: service_healthy
|
|
db-slave:
|
|
condition: service_healthy
|
|
healthcheck:
|
|
test: ["CMD-SHELL", "pg_isready -h 127.0.0.1 -p 6432 -U e-ticket"]
|
|
interval: 5s
|
|
timeout: 5s
|
|
retries: 5
|
|
|
|
messenger:
|
|
build:
|
|
context: ./docker/php/prod
|
|
dockerfile: Dockerfile
|
|
command: php bin/console messenger:consume async --time-limit=3600 --memory-limit=256M --limit=500 -vv
|
|
deploy:
|
|
replicas: 2
|
|
restart: unless-stopped
|
|
volumes:
|
|
- .:/app
|
|
networks:
|
|
- e-ticket
|
|
depends_on:
|
|
pgbouncer:
|
|
condition: service_healthy
|
|
redis:
|
|
condition: service_healthy
|
|
meilisearch:
|
|
condition: service_started
|
|
|
|
redis:
|
|
image: redis:7-alpine
|
|
restart: unless-stopped
|
|
command: redis-server --requirepass {{ redis_password }}
|
|
volumes:
|
|
- redis-data:/data
|
|
networks:
|
|
- e-ticket
|
|
healthcheck:
|
|
test: ["CMD", "redis-cli", "-a", "{{ redis_password }}", "ping"]
|
|
interval: 5s
|
|
timeout: 5s
|
|
retries: 5
|
|
|
|
meilisearch:
|
|
image: getmeili/meilisearch:latest
|
|
restart: unless-stopped
|
|
environment:
|
|
MEILI_MASTER_KEY: {{ meilisearch_master_key }}
|
|
MEILI_ENV: production
|
|
MEILI_NO_ANALYTICS: true
|
|
volumes:
|
|
- meilisearch-data:/meili_data
|
|
networks:
|
|
- e-ticket
|
|
networks:
|
|
e-ticket:
|
|
driver: bridge
|
|
|
|
volumes:
|
|
db-master-data:
|
|
db-slave-data:
|
|
redis-data:
|
|
meilisearch-data:
|