version: "2.2" services: app: image: xf/fisk:prod container_name: fisk build: context: . args: OPERATION: ${OPERATION} volumes: - ${PORTAINER_GIT_DIR}:/code - ${PORTAINER_GIT_DIR}/docker/uwsgi.ini:/conf/uwsgi.ini - ${APP_DATABASE_FILE}:/conf/db.sqlite3 - fisk_static:${STATIC_ROOT} #ports: # - "8000:8000" # uwsgi socket env_file: - stack.env volumes_from: - tmp depends_on: # redis: # condition: service_healthy migration: condition: service_started collectstatic: condition: service_started networks: - default - xf - elastic scheduling: image: xf/fisk:prod container_name: scheduling_fisk build: context: . args: OPERATION: ${OPERATION} command: sh -c '. /venv/bin/activate && python manage.py scheduling' volumes: - ${PORTAINER_GIT_DIR}:/code - ${PORTAINER_GIT_DIR}/docker/uwsgi.ini:/conf/uwsgi.ini - ${APP_DATABASE_FILE}:/conf/db.sqlite3 - fisk_static:${STATIC_ROOT} env_file: - stack.env volumes_from: - tmp depends_on: redis: condition: service_healthy migration: condition: service_started collectstatic: condition: service_started networks: - default - xf - elastic migration: image: xf/fisk:prod container_name: migration_fisk build: context: . args: OPERATION: ${OPERATION} command: sh -c '. /venv/bin/activate && python manage.py migrate --noinput' volumes: - ${PORTAINER_GIT_DIR}:/code - ${APP_DATABASE_FILE}:/conf/db.sqlite3 - fisk_static:${STATIC_ROOT} volumes_from: - tmp env_file: - stack.env collectstatic: image: xf/fisk:prod container_name: collectstatic_fisk build: context: . args: OPERATION: ${OPERATION} command: sh -c '. /venv/bin/activate && python manage.py collectstatic --noinput' volumes: - ${PORTAINER_GIT_DIR}:/code - ${APP_DATABASE_FILE}:/conf/db.sqlite3 - fisk_static:${STATIC_ROOT} volumes_from: - tmp env_file: - stack.env nginx: image: nginx:latest container_name: nginx_fisk ports: - ${APP_PORT}:9999 ulimits: nproc: 65535 nofile: soft: 65535 hard: 65535 volumes: - ${PORTAINER_GIT_DIR}:/code - ${PORTAINER_GIT_DIR}/docker/nginx/conf.d/${OPERATION}.conf:/etc/nginx/conf.d/default.conf - fisk_static:${STATIC_ROOT} volumes_from: - tmp networks: - default - xf depends_on: app: condition: service_started # volumes_from: # - tmp # depends_on: # redis: # condition: service_healthy tmp: image: busybox container_name: tmp_fisk command: chmod -R 777 /var/run/socks volumes: - /var/run/socks # For caching redis: image: redis container_name: redis_fisk command: redis-server /etc/redis.conf ulimits: nproc: 65535 nofile: soft: 65535 hard: 65535 volumes: - ${PORTAINER_GIT_DIR}/docker/redis.conf:/etc/redis.conf - fisk_redis_data:/data volumes_from: - tmp healthcheck: test: "redis-cli -s /var/run/socks/redis.sock ping" interval: 2s timeout: 2s retries: 15 # pyroscope: # image: "pyroscope/pyroscope:latest" # ports: # - "4040:4040" # command: # - "server" networks: default: driver: bridge xf: external: true elastic: external: true volumes: fisk_static: {} fisk_redis_data: {}