启用Dashboard
K3s (≥1.21)默认没有启用 Traefik Dashboard。如果要在 K3s 中启用 Dashborad,我们可以借助 HelmChartConfig 来自定义由 Helm 部署的 Traefik 并启用 Dashboard。
不建议手动编辑
/var/lib/rancher/K3s/server/manifests/traefik.yaml
来修改 Traefik 配置文件,因为 K3s 重启后会覆盖修改的内容。建议通过在
/var/lib/rancher/K3s/server/manifests
中创建一个额外的HelmChartConfig
清单来自定义 Traefik 配置,请参考:http://docs.rancher.cn/docs/K3
1 | cat >> /var/lib/rancher/K3s/server/manifests/traefik-config.yaml << EOF |
K8s 修改 traefik-vlues.yaml 中ingressRoute.dashboard
并应用配置
1 | helm upgrade traefik traefik/traefik \ |
配置Service及路由规则
1 | cat >> traefik-dashboard.yaml << EOF |
1 | kubectl apply -f traefik-dashboard.yaml |
访问Dashboard需要在最后加一个/
否则可能出现page not found
配置IngressRoute
1 | # 搭建测试环境 |
HTTP
1 | #whoami-no-tls-ingress-route.yaml |
HTTPS
1 | # 用 openssl 来创建一个自签名的证书 |
1 | # whoami-tls-ingress-route.yaml |
证书生成参考[[K3s证书管理]]
TCP/UDP
默认配置文件下,只有traefik
(9000)、web
(80)、websecure
(443)以及metrics
(9100)开放,如果想要反代MySQL tcp又想自定义端口的话,需要单独在配置文件中进行配置。
1 | apiVersion: traefik.containo.us/v1alpha1 |
TCP Routers与HTTP Routers的routes有所不同:
- TCP Routers match采用HostSNI,而HTTP Routers match直接匹配Host。
- TCP Routers只能定位TCP服务(不能定位HTTP服务)。
- 如果HTTP Routers和TCP Routers都侦听相同的入口点,则TCP Routers将在HTTP Routers之前应用。如果找不到与TCP Routers匹配的路由,则HTTP Routers将接管。
参考
K3s版本 > v.121(Traefik 2.x)
K3S 中 Traefik v2 安装及采坑纪实 - 知乎 (zhihu.com)
k3s开启traefik的dashboard网页-CSDN博客
Step by Step!教你如何在k3s集群上使用Traefik 2.x - k3s中文社区 - 博客园 (cnblogs.com)
traefik系列之一 | 简介、部署和配置-腾讯云开发者社区-腾讯云 (tencent.com)
还不会Traefik?看这篇文章就够了! - 知乎 (zhihu.com)
k3s 使用 Letsencrypt 和 Traefik 完成 https 入口部署-腾讯云开发者社区-腾讯云 (tencent.com)
[Kubernetes环境Traefik部署与应用 - Tiscs - 博客园 (cnblogs.com)](https://www.cnblogs.com/tiscs/p/notes-k8s-traefik.html#:~:text=安装Traefik 1 配置 Helm Repo helm repo add, … 3 其他准备工作 获取 traefik 服务的负载均衡器地址。 )
Traefik - Kubernetes 配置TCP/HTTP服务-腾讯云开发者社区-腾讯云 (tencent.com)
cert-manager管理内网k8s开发环境证书 - hueidou163 - 博客园 (cnblogs.com)
Kubernetes (K8S)中Traefik路由(ingressRoute)-腾讯云开发者社区-腾讯云 (tencent.com)
Dashboard无法访问问题参考
如何在 K3s 中启用 Traefik Dashborad - RancherLabs - 博客园 (cnblogs.com)
How to Expose and Enable K3s with Traefik Dashboard (thriveread.com)
kubernetes - How to expose traefik v2 dashboard in k3d/k3s via configuration? - Stack Overflow
kubernetes - 云原生 07:改用 K3s,并使用 K3s 内置的 Traefik 做 Ingress 网关 - 小鲜 - SegmentFault 思否