--- version: "3.8" services: app: image: redmine:5 networks: - proxy - internal environment: REDMINE_DB_POSTGRES: db REDMINE_DB_DATABASE: redmine REDMINE_DB_USERNAME: redmine REDMINE_DB_PASSWORD_FILE: /run/secrets/db_password REDMINE_SECRET_KEY_BASE_FILE: /run/secrets/key_base REDMINE_PLUGINS_MIGRATE: "true" secrets: - db_password - key_base deploy: restart_policy: condition: on-failure labels: - "traefik.enable=true" - "traefik.http.services.${STACK_NAME}.loadbalancer.server.port=3000" - "traefik.http.routers.${STACK_NAME}.rule=Host(`${DOMAIN}`${EXTRA_DOMAINS})" - "traefik.http.routers.${STACK_NAME}.entrypoints=web-secure" - "traefik.http.routers.${STACK_NAME}.tls.certresolver=${LETS_ENCRYPT_ENV}" - "coop-cloud.${STACK_NAME}.version=" healthcheck: test: ["CMD", "curl", "-f", "http://localhost:3000"] interval: 30s timeout: 10s retries: 10 start_period: 1m db: image: postgres:13-alpine secrets: - db_password environment: - POSTGRES_DB=redmine - POSTGRES_PASSWORD_FILE=/run/secrets/db_password - POSTGRES_USER=redmine networks: - internal healthcheck: test: ["CMD", "pg_isready", "-U", "redmine"] volumes: - db:/var/lib/postgresql/data deploy: labels: backupbot.backup: "true" backupbot.backup.pre-hook: "mkdir -p /tmp/backup/ && PGPASSWORD=$$(cat $${POSTGRES_PASSWORD_FILE}) pg_dump -U $${POSTGRES_USER} $${POSTGRES_DB} > /tmp/backup/backup.sql" backupbot.backup.post-hook: "rm -rf /tmp/backup" backupbot.backup.path: "/tmp/backup/" volumes: db: secrets: db_password: external: true name: ${STACK_NAME}_db_password_${SECRET_DB_PASSWORD_VERSION} key_base: external: true name: ${STACK_NAME}_key_base_${SECRET_KEY_BASE_VERSION} networks: internal: proxy: external: true