version: "3.6" volumes: logs: media: postgres-data: static-files: services: db: image: postgres:15 healthcheck: test: /usr/bin/pg_isready interval: 5s timeout: 10s retries: 10 env_file: ./.env volumes: - postgres-data:/var/lib/postgresql/data rabbitmq: image: rabbitmq:3.7 memcached: image: memcached:1.6 entrypoint: - memcached - -m 64 celery: build: context: . dockerfile: ./docker/django target: production args: POSTGRES_HOST: POSTGRES_PORT: POSTGRES_DB: POSTGRES_USER: POSTGRES_PASSWORD: DJANGO_SECRET_KEY: DJANGO_SETTINGS_MODULE: "newsreader.conf.production" command: | celery worker -n worker1@%h -n worker2@%h --app newsreader --loglevel INFO --concurrency 2 --workdir /app/src/ --beat --scheduler django environment: - DJANGO_SETTINGS_MODULE=newsreader.conf.production depends_on: rabbitmq: condition: service_started memcached: condition: service_started db: condition: service_healthy django: condition: service_healthy volumes: - logs:/app/logs django: build: context: . dockerfile: ./docker/django target: production args: POSTGRES_HOST: POSTGRES_PORT: POSTGRES_DB: POSTGRES_USER: POSTGRES_PASSWORD: DJANGO_SECRET_KEY: DJANGO_SETTINGS_MODULE: "newsreader.conf.production" entrypoint: /app/bin/docker-entrypoint.sh command: | gunicorn --bind 0.0.0.0:8000 --workers 3 --chdir /app/src/ newsreader.wsgi:application healthcheck: test: /usr/bin/curl --fail http://django:8000 || exit 1 interval: 30s timeout: 10s retries: 10 env_file: ./.env environment: - DJANGO_SETTINGS_MODULE=newsreader.conf.production depends_on: memcached: condition: service_started db: condition: service_healthy volumes: - logs:/app/logs - media:/app/media - static-files:/app/static