Traefik全面使用指南:部署篇
本文最后更新于 319 天前, 如有失效请评论区留言.
本文聊聊如何通过 k3s 如何部署 Traefik
什么是 Traefik
Traefik 是一个用于反向代理和负载均衡的现代化 HTTP 反向代理服务器和负载均衡器。
主要特性
仅列出我使用的特性
- 自动发现和动态配置 可以与容器管理平台如 Docker、Kubernetes 集成,并根据服务的变化自动更新路由规则
- 负载均衡
- 动态路由
- 内置的 Let's Encrypt 集成
- 丰富的插件和中间件机制, 如 IP 白名单等
部署
其实,官网文档已经很全了,这里仅列出一些个性化的设置。
helm repo add traefik https://traefik.github.io/charts
helm repo update
添加官网 helm 仓库,并更新
自定义配置
image:
registry: ccr.ccs.tencentyun.com
repository: k7scn/traefik
ingressClass:
isDefaultClass: false
ingressRoute:
healthcheck:
enabled: true
providers:
kubernetesCRD:
enabled: true
allowCrossNamespace: true
allowExternalNameServices: true
allowEmptyServices: true
kubernetesIngress:
enabled: true
allowExternalNameServices: true
allowEmptyServices: true
publishedService:
enabled: true
additionalArguments:
- "--certificatesresolvers.myresolver.acme.email=traefik-tls@ysicing.net"
- "--certificatesresolvers.myresolver.acme.storage=/data/acme.json"
- "--certificatesresolvers.myresolver.acme.httpchallenge=true"
- "--certificatesresolvers.myresolver.acme.httpchallenge.entrypoint=web"
- "--api=true"
ports:
traefik:
port: 9000
expose: true
web:
port: 8000
hostPort: 80
websecure:
port: 8443
hostPort: 443
http3:
enabled: true
metrics:
expose: true
nodeSelector:
node-role.kubernetes.io/bj: "true"
tolerations: []
persistence:
enabled: true
log:
access:
enabled: true
其实也添加 tls 相关及限定了调度到哪台机器上。
部署
也可以不指定版本。如果不指定版本需要去掉 values.yaml
关于 registry 部分的配置
kubectl create ns traefik-v2
helm upgrade -i traefik traefik/traefik -n traefik-v2 -f ./values.yaml --version 26.0.0
其他问题
可能会提示对 /data/acme.json
没有权限,手动处理一下这个权限。
由于我是多云集群,默认全局 sc 是 hostpath,直接去相关节点手动新建这个文件即可, 路径大概是 /var/lib/rancher/k3s/storage/[traefik-pvc]
, 具体 pvc 需要自行看下,如果没跑服务应该就 1 个就是 traefik 的
touch ./acme.json
chmod -v 600 ./acme.json
chown 65532.65532 acme.json
这个也可以通过 initContainer 去处理, 具体可以参考 traefik/values.yaml#L65
测试
这里我提供一个测试 yaml
apiVersion: v1
kind: Service
metadata:
name: whoami
spec:
ports:
- protocol: TCP
name: web
port: 80
selector:
app: whoami
---
kind: Deployment
apiVersion: apps/v1
metadata:
name: whoami
labels:
app: whoami
spec:
replicas: 2
selector:
matchLabels:
app: whoami
template:
metadata:
labels:
app: whoami
spec:
nodeSelector:
node-role.kubernetes.io/bj: "true"
containers:
- name: whoami
image: h2.ysicing.net/containous/whoami
resources:
limits:
cpu: 100m
memory: 128M
ports:
- name: web
containerPort: 80
---
apiVersion: traefik.containo.us/v1alpha1
kind: IngressRoute
metadata:
name: whoami-http
spec:
entryPoints:
- web
routes:
- match: Host(`whoami.bjslb.ysicing.net`) && PathPrefix(`/notls`)
kind: Rule
services:
- name: whoami
port: 80
---
apiVersion: traefik.containo.us/v1alpha1
kind: IngressRoute
metadata:
name: whoami-https
spec:
entryPoints:
- websecure
routes:
- match: Host(`whoami.bjslb.ysicing.net`) && PathPrefix(`/tls`)
kind: Rule
services:
- name: whoami
port: 80
tls:
certResolver: myresolver