我想在我的本地机器上安装开发设置,以便更轻松地测试我的程序的新版本 - 它是一个服务器/客户端应用程序 . 客户端确实需要SSL,因此我希望将traefik作为使用自签名证书的(本地)服务器的代理 .
我设法在没有SSL的情况下获得连接但是只要启用HTTPS /重定向,traefik就会响应 "backend not found" "/" 0ms .
根据我的浏览器,SSL证书有效 .
这是我的设置:
traefik.toml
[docker]
watch = true
exposedByDefault = false
logLevel = "DEBUG"
defaultEntryPoints = ["https", "http"]
[accessLog]
[traefikLog]
[entryPoints]
[entryPoints.http]
address = ":80"
[entryPoints.http.redirect]
entryPoint = "https"
[entryPoints.https]
address = ":443"
[entryPoints.https.tls]
[[entryPoints.https.tls.certificates]]
ca = "etc/traefik/ca.cert.pem"
certFile = "/etc/traefik/dev-cert.pem"
keyFile = "/etc/traefik/dev-key.nopass.pem"
# API definition
[api]
entryPoint = "traefik"
dashboard = true
docker-compose.yaml
version: '3'
services:
edv-reverse-proxy:
image: traefik
container_name: edv-reverse-proxy
expose:
- 8080
ports:
- 80:80
- 443:443
- 8080:8080
volumes:
- ./traefik/dev-cert.pem:/etc/traefik/dev-cert.pem
- ./traefik/dev-key.nopass.pem:/etc/traefik/dev-key.nopass.pem
- ./traefik/ca.cert.pem:/etc/traefik/ca.cert.pem
- ./traefik/traefik.toml:/etc/traefik/traefik.toml
- /var/run/docker.sock:/var/run/docker.sock
networks:
- proxy
whoami:
image: emilevauge/whoami
expose:
- 80
labels:
- traefik.enable=true
- "traefik.frontend.rule=Host:whoami.test"
- traefik.port=80
networks:
- proxy
networks:
proxy:
external: true
/etc/hosts
127.0.0.1 whoami.test
如果我禁用整个入口点部分,我可以使用whoami.test连接到服务 . 我尝试了很多不同的设置,似乎没有任何效果 .
所以,如果有人知道如何解决这个问题,我真的很高兴!
1 回答
字段顺序在toml中很重要: