Neda/Back/docker-compose.yml

105 lines
2.4 KiB
YAML
Executable File

services:
postgres:
image: postgres:17-alpine
container_name: neda_postgres
environment:
POSTGRES_DB: ${POSTGRES_DB}
POSTGRES_USER: ${POSTGRES_USER}
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
volumes:
- postgres_data:/var/lib/postgresql/data
restart: always
healthcheck:
test: [ "CMD-SHELL", "pg_isready -U ${POSTGRES_USER} -d ${POSTGRES_DB}" ]
interval: 5s
timeout: 5s
retries: 3
redis:
image: redis:7-alpine
container_name: neda_redis
volumes:
- redis_data:/data
restart: always
healthcheck:
test: [ "CMD", "redis-cli", "ping" ]
interval: 5s
timeout: 3s
retries: 5
livekit:
image: livekit/livekit-server
container_name: neda_livekit
ports:
- "7780:7880"
- "7781:7881"
- "50000-50100:50000-50100/udp"
env_file:
- .env
volumes:
- ./livekit.yaml:/etc/livekit/livekit.yaml
command: [ "--config", "/etc/livekit/livekit.yaml", "--keys", "${LIVEKIT_API_KEY}: ${LIVEKIT_API_SECRET}" ]
restart: always
pgadmin:
image: dpage/pgadmin4:latest
container_name: neda_pgadmin
restart: always
ports:
- "5050:80"
environment:
PGADMIN_DEFAULT_EMAIL: ${PGADMIN_DEFAULT_EMAIL}
PGADMIN_DEFAULT_PASSWORD: ${PGADMIN_DEFAULT_PASSWORD}
PGADMIN_CONFIG_SERVER_MODE: 'True'
PGADMIN_CONFIG_UPGRADE_CHECK_ENABLED: 'False'
PGADMIN_CONFIG_MASTER_PASSWORD_REQUIRED: 'False'
volumes:
- pgadmin_data:/var/lib/pgadmin
depends_on:
- postgres
pg_backup:
image: prodrigestivill/postgres-backup-local
container_name: neda_pg_backup
restart: always
profiles:
- "prod"
volumes:
- ./backups:/backups
environment:
POSTGRES_HOST: postgres
POSTGRES_DB: ${POSTGRES_DB}
POSTGRES_USER: ${POSTGRES_USER}
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
SCHEDULE: '@daily'
BACKUP_KEEP_DAYS: 7
depends_on:
postgres:
condition: service_healthy
api:
build: .
container_name: neda_api
ports:
- "8000:8000"
volumes:
- "./:/app"
env_file:
- .env
depends_on:
postgres:
condition: service_healthy
redis:
condition: service_healthy
livekit:
condition: service_started
restart: always
volumes:
postgres_data:
redis_data:
pgadmin_data: