K3s 配置 Traefik Ingress
启用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 思否