services: db: image: postgres:15.10 container_name: state_corp_db restart: unless-stopped environment: POSTGRES_DB: ${POSTGRES_DB} POSTGRES_USER: ${POSTGRES_USER} POSTGRES_PASSWORD: ${POSTGRES_PASSWORD} volumes: - ./data/db:/var/lib/postgresql/data ports: - "5432:5432" networks: - state_corp_network healthcheck: test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER}"] interval: 30s timeout: 10s retries: 3 redis: image: redis:7-alpine container_name: state_corp_redis restart: unless-stopped ports: - "6379:6379" volumes: - ./data/redis:/data networks: - state_corp_network healthcheck: test: ["CMD", "redis-cli", "ping"] interval: 30s timeout: 10s retries: 3 web: image: 10.10.0.10:3000/avm/state_corp-web:${IMAGE_TAG:-dev} container_name: state_corp_web restart: unless-stopped depends_on: db: condition: service_healthy redis: condition: service_healthy environment: - DEBUG=False - SECRET_KEY=${SECRET_KEY} - POSTGRES_HOST=db - POSTGRES_PORT=5432 - POSTGRES_DB=${POSTGRES_DB} - POSTGRES_USER=${POSTGRES_USER} - POSTGRES_PASSWORD=${POSTGRES_PASSWORD} - REDIS_URL=redis://redis:6379/0 - CELERY_BROKER_URL=redis://redis:6379/0 - CELERY_RESULT_BACKEND=redis://redis:6379/0 volumes: - ./logs:/app/logs - ./media:/app/media - ./staticfiles:/app/staticfiles ports: - "8000:8000" command: > sh -c "python src/manage.py migrate && python src/manage.py collectstatic --noinput && gunicorn config.wsgi:application --bind 0.0.0.0:8000 --workers 3" celery_worker: image: 10.10.0.10:3000/avm/state_corp-celery:${IMAGE_TAG:-dev} container_name: state_corp_celery_worker restart: unless-stopped depends_on: db: condition: service_healthy redis: condition: service_healthy environment: - DEBUG=False - POSTGRES_HOST=db - POSTGRES_PORT=5432 - POSTGRES_DB=${POSTGRES_DB} - POSTGRES_USER=${POSTGRES_USER} - POSTGRES_PASSWORD=${POSTGRES_PASSWORD} - REDIS_URL=redis://redis:6379/0 - CELERY_BROKER_URL=redis://redis:6379/0 - CELERY_RESULT_BACKEND=redis://redis:6379/0 volumes: - ./logs:/app/logs networks: - state_corp_network command: celery -A config worker --loglevel=info celery_beat: image: 10.10.0.10:3000/avm/state_corp-celery:${IMAGE_TAG:-dev} container_name: state_corp_celery_beat restart: unless-stopped depends_on: db: condition: service_healthy redis: condition: service_healthy environment: - DEBUG=False - POSTGRES_HOST=db - POSTGRES_PORT=5432 - POSTGRES_DB=${POSTGRES_DB} - POSTGRES_USER=${POSTGRES_USER} - POSTGRES_PASSWORD=${POSTGRES_PASSWORD} - REDIS_URL=redis://redis:6379/0 - CELERY_BROKER_URL=redis://redis:6379/0 - CELERY_RESULT_BACKEND=redis://redis:6379/0 volumes: - ./logs:/app/logs networks: - state_corp_network command: celery -A config beat --loglevel=info --scheduler django_celery_beat.schedulers:DatabaseScheduler networks: state_corp_network: driver: bridge