Я пытаюсь заставить Traefik и Stapi CMS работать вместе, но у меня возникают проблемы при попытке получить доступ к панели администратора. Например, я разверну обе службы и получу доступ к CMS через cms.example.com, который загружает public / index.html в соответствии с strapi, как и ожидалось.
Проблема в том, что когда я пытаюсь получить доступ к cms.example.com/admin, запрос снова возвращает страницу public / index.html, а не страницу администратора. Я также проверил вывод strapi для обоих запросов, похоже, он запрашивает один и тот же маршрут.
Может ли кто-нибудь посоветовать мне, как определить, связана ли ошибка с тем, что Traefik не отправляет путь, или это Strapi вылетает из строя?
Вот некоторые подробности о развертывании:
- Развертывание Traefik:
docker run -d -v /var/run/docker.sock:/var/run/docker.sock -v $PWD/traefik.toml:/traefik.toml -p 80:80 -p 443:443 -p 8080:8080 --network web --name traefik traefik:2.0.2
- Strapi docker-compose:
version: '3.1'
services:
strapi:
image: strapi/strapi
environment:
- DATABASE_CLIENT=postgres
- DATABASE_HOST=strapi-db
- DATABASE_PORT=5432
- DATABASE_NAME=strapi
- DATABASE_USERNAME=strapi
- DATABASE_PASSWORD=strapi
ports:
- 9020:1337
labels:
- "traefik.enable=true"
- "traefik.http.routers.circulate.rule=Host(`cms.circulate.co.za`)"
- "traefik.http.routers.circulate.entrypoints=web"
- "traefik.docker.network=web"
- "traefik.http.middlewares.circulate.addprefix.prefix=/foo"
- "traefik.port=80"
networks:
- internal
- web
volumes:
- ./app:/srv/app
depends_on:
- strapi-db
command: 'strapi start'
strapi-db:
image: postgres:12.1
restart: always
networks:
- internal
- web
volumes:
- strapi-vol:/var/lib/postgresql/data
environment:
POSTGRES_USER: strapi
POSTGRES_PASSWORD: strapi
POSTGRES_DB: strapi
volumes:
strapi-vol:
networks:
web:
external: true
internal:
external: false
Файл Traefik TOML:
################################################################
# Global configuration
################################################################
[global]
checkNewVersion = true
sendAnonymousUsage = true
################################################################
# Entrypoints configuration
################################################################
# Entrypoints definition
#
# Optional
# Default:
[entryPoints]
[entryPoints.web]
address = ":80"
[entryPoints.websecure]
address = ":443"
################################################################
# Traefik logs configuration
################################################################
# Traefik logs
# Enabled by default and log to stdout
#
# Optional
#
[log]
# Log level
#
# Optional
# Default: "ERROR"
#
level = "INFO"
# Sets the filepath for the traefik log. If not specified, stdout will be used.
# Intermediate directories are created if necessary.
#
# Optional
# Default: os.Stdout
#
filePath = "log/traefik.log"
# Format is either "json" or "common".
#
# Optional
# Default: "common"
#
format = "json"
################################################################
# Access logs configuration
################################################################
# Enable access logs
# By default it will write to stdout and produce logs in the textual
# Common Log Format (CLF), extended with additional fields.
#
# Optional
#
# [accessLog]
# Sets the file path for the access log. If not specified, stdout will be used.
# Intermediate directories are created if necessary.
#
# Optional
# Default: os.Stdout
#
# filePath = "/path/to/log/log.txt"
# Format is either "json" or "common".
#
# Optional
# Default: "common"
#
# format = "json"
################################################################
# API and dashboard configuration
################################################################
# Enable API and dashboard
[api]
# Name of the related entry point
#
# Optional
# Default: "traefik"
#
# entryPoint = "traefik"
# Enabled Dashboard
#
# Optional
# Default: true
#
dashboard = true
insecure = true
################################################################
# Ping configuration
################################################################
# Enable ping
[ping]
# Name of the related entry point
#
# Optional
# Default: "traefik"
#
# entryPoint = "traefik"
################################################################
# Docker configuration backend
################################################################
# Enable Docker configuration backend
[providers.docker]
# Docker server endpoint. Can be a tcp or a unix socket endpoint.
#
# Required
# Default: "unix:///var/run/docker.sock"
#
# endpoint = "tcp://10.10.10.10:2375"
# Default host rule.
#
# Optional
# Default: "Host(`{{ normalize .Name }}`)"
#
# defaultRule = "Host(`{{ normalize .Name }}.docker.localhost`)"
# Expose containers by default in traefik
#
# Optional
# Default: true
#
network = "web"
watch = true
exposedByDefault = false