--- version: "3.8" services: app: image: libretime/icecast:2.5-beta3 networks: - proxy environment: - ICECAST_HOSTNAME=$DOMAIN - ICECAST_SOURCE_PASSWORD - ICECAST_ADMIN_PASSWORD - ICECAST_LOCATION deploy: restart_policy: condition: on-failure labels: - "traefik.enable=true" # TCP router, handle streaming to Icecast # !! Works only with HostSNI(*) and TLS off !! - 'traefik.tcp.routers.${STACK_NAME}-tcp.rule=HostSNI(`*`)' - 'traefik.tcp.routers.${STACK_NAME}-tcp.entrypoints=web-alt' - 'traefik.tcp.routers.${STACK_NAME}-tcp.tls=false' - 'traefik.tcp.routers.${STACK_NAME}-tcp.service=${STACK_NAME}-tcp' - 'traefik.tcp.services.${STACK_NAME}-tcp.loadbalancer.server.port=8000' # HTTPS router - "traefik.http.services.${STACK_NAME}.loadbalancer.server.port=8000" - "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}" - "coop-cloud.${STACK_NAME}.version=1.0.0+2.5-beta3" # healthcheck: # test: ["CMD", "curl", "-f", "http://localhost:8000"] # interval: 30s # timeout: 10s # retries: 10 # start_period: 1m networks: proxy: external: true