--- version: "3.8" services: app: image: nginx:alpine working_dir: /app volumes: - wordpress:/app:cached networks: - proxy - backend configs: - source: nginx_conf target: /etc/nginx/conf.d/default.conf:cached deploy: restart_policy: condition: on-failure labels: - "traefik.enable=true" - "traefik.http.services.${STACK_NAME}.loadbalancer.server.port=80" - "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}" ## Redirect from EXTRA_DOMAINS to DOMAIN #- "traefik.http.routers.${STACK_NAME}.middlewares=${STACK_NAME}-redirect" #- "traefik.http.middlewares.${STACK_NAME}-redirect.headers.SSLForceHost=true" #- "traefik.http.middlewares.${STACK_NAME}-redirect.headers.SSLHost=${DOMAIN}" # healthcheck: # test: ["CMD", "curl", "-f", "http://localhost"] # interval: 30s # timeout: 10s # retries: 10 # start_period: 1m php: image: "thecoopcloud/wordpress:5.8.2-php8.0-fpm-bedrock" working_dir: /app environment: - DB_NAME=wordpress - DB_USER=wordpress - DB_PASSWORD=wordpress - WP_ENV=production - WP_HOME=https://${DOMAIN} networks: - backend volumes: - wordpress:/app:cached db: image: mariadb:10.4 networks: - backend volumes: - "mariadb:/var/lib/mysql" environment: - MYSQL_ROOT_PASSWORD=wordpress - MYSQL_DATABASE=wordpress - MYSQL_USER=wordpress - MYSQL_PASSWORD=wordpress image: nginx:1.19.2 networks: - proxy networks: proxy: external: true backend: volumes: wordpress: mariadb: configs: nginx_conf: name: ${STACK_NAME}_nginx_conf_${NGINX_CONF_VERSION} file: nginx.conf