Kubernetes 部署 Ingress 控制器 Traefik v2.0

Kubernetes 部署 Ingress 控制器 Traefik v2.0

文章目录

  !版权声明:本博客内容均为原创,每篇博文作为知识积累,写博不易,转载请注明出处。


系统环境:

  • Traefik 版本:v2.0.5
  • Kubernetes 版本:1.16.3

地址:

  • Traefik 2.0 官方文档:https://docs.traefik.io/v2.0/
  • 部署文件的 Github 地址:https://github.com/my-dlq/blog-example/tree/master/kubernetes/traefik-v2.0-deploy

一、Traefik 简介

Traefik 是一个流行的 HTTP 反向代理和负载均衡器,使用 Traefik 可以很方便的与现在流程的基础架构组件(如 Docker、Swarm、Kubernetes、Marathon、Consul、Etcd、Rancher、Amazon ECS ......)集成,并可以针对不同的组件实现动态配置。

二、Kubernetes 部署 Traefik

注意:这里 Traefik 是部署在 Kube-system Namespace 下,如果不是需要修改下面部署文件中的 Namespace 属性。

1、创建 CRD 资源

在 traefik v2.0 版本后,开始使用 CRD(Custom Resource Definition)来完成路由配置等,所以需要提前创建 CRD 资源。

创建 traefik-crd.yaml 文件

 1## IngressRoute
 2apiVersion: apiextensions.k8s.io/v1beta1
 3kind: CustomResourceDefinition
 4metadata:
 5  name: ingressroutes.traefik.containo.us
 6spec:
 7  scope: Namespaced
 8  group: traefik.containo.us
 9  version: v1alpha1
10  names:
11    kind: IngressRoute
12    plural: ingressroutes
13    singular: ingressroute
14---
15## IngressRouteTCP
16apiVersion: apiextensions.k8s.io/v1beta1
17kind: CustomResourceDefinition
18metadata:
19  name: ingressroutetcps.traefik.containo.us
20spec:
21  scope: Namespaced
22  group: traefik.containo.us
23  version: v1alpha1
24  names:
25    kind: IngressRouteTCP
26    plural: ingressroutetcps
27    singular: ingressroutetcp
28---
29## Middleware
30apiVersion: apiextensions.k8s.io/v1beta1
31kind: CustomResourceDefinition
32metadata:
33  name: middlewares.traefik.containo.us
34spec:
35  scope: Namespaced
36  group: traefik.containo.us
37  version: v1alpha1
38  names:
39    kind: Middleware
40    plural: middlewares
41    singular: middleware
42---
43apiVersion: apiextensions.k8s.io/v1beta1
44kind: CustomResourceDefinition
45metadata:
46  name: tlsoptions.traefik.containo.us
47spec:
48  scope: Namespaced
49  group: traefik.containo.us
50  version: v1alpha1
51  names:
52    kind: TLSOption
53    plural: tlsoptions
54    singular: tlsoption

创建 Traefik CRD 资源

1$ kubectl apply -f traefik-crd.yaml

2、创建 RBAC 权限

Kubernetes 在 1.6 版本中引入了基于角色的访问控制(RBAC)策略,方便对 Kubernetes 资源和 API 进行细粒度控制。Traefik 需要一定的权限,所以这里提前创建好 Traefik ServiceAccount 并分配一定的权限。

创建 traefik-rbac.yaml 文件

 1apiVersion: v1
 2kind: ServiceAccount
 3metadata:
 4  namespace: kube-system
 5  name: traefik-ingress-controller
 6---
 7kind: ClusterRole
 8apiVersion: rbac.authorization.k8s.io/v1beta1
 9metadata:
10  name: traefik-ingress-controller
11rules:
12  - apiGroups: [""]
13    resources: ["services","endpoints","secrets"]
14    verbs: ["get","list","watch"]
15  - apiGroups: ["extensions"]
16    resources: ["ingresses"]
17    verbs: ["get","list","watch"]
18  - apiGroups: ["extensions"]
19    resources: ["ingresses/status"]
20    verbs: ["update"]
21  - apiGroups: ["traefik.containo.us"]
22    resources: ["middlewares"]
23    verbs: ["get","list","watch"]
24  - apiGroups: ["traefik.containo.us"]
25    resources: ["ingressroutes"]
26    verbs: ["get","list","watch"]
27  - apiGroups: ["traefik.containo.us"]
28    resources: ["ingressroutetcps"]
29    verbs: ["get","list","watch"]
30  - apiGroups: ["traefik.containo.us"]
31    resources: ["tlsoptions"]
32    verbs: ["get","list","watch"]
33---
34kind: ClusterRoleBinding
35apiVersion: rbac.authorization.k8s.io/v1beta1
36metadata:
37  name: traefik-ingress-controller
38roleRef:
39  apiGroup: rbac.authorization.k8s.io
40  kind: ClusterRole
41  name: traefik-ingress-controller
42subjects:
43  - kind: ServiceAccount
44    name: traefik-ingress-controller
45    namespace: kube-system

创建 Traefik RBAC 资源

  • -n:指定部署的 Namespace
1$ kubectl apply -f traefik-rbac.yaml -n kube-system

3、创建 Traefik 配置文件

由于 Traefik 配置很多,通过 CLI 定义不是很方便,一般时候选择将其配置选项放到配置文件中,然后存入 ConfigMap,将其挂入 traefik 中。

创建 traefik-config.yaml 文件

 1kind: ConfigMap
 2apiVersion: v1
 3metadata:
 4  name: traefik-config
 5data:
 6  traefik.yaml: |-
 7    serversTransport:
 8      insecureSkipVerify: true
 9    api:
10      insecure: true
11      dashboard: true
12      debug: true
13    metrics:
14      prometheus: ""
15    entryPoints:
16      web:
17        address: ":80"
18      websecure:
19        address: ":443"
20    providers:
21      kubernetesCRD: ""
22    log:
23      filePath: ""
24      level: error
25      format: json
26    accessLog:
27      filePath: ""
28      format: json
29      bufferingSize: 0
30      filters:
31        retryAttempts: true
32        minDuration: 20
33      fields:
34        defaultMode: keep
35        names:
36          ClientUsername: drop
37        headers:
38          defaultMode: keep
39          names:
40            User-Agent: redact
41            Authorization: drop
42            Content-Type: keep    

创建 Traefik ConfigMap 资源

  • -n: 指定程序启的 Namespace
1$ kubectl apply -f traefik-config.yaml -n kube-system

4、节点设置 Label 标签

由于是 Kubernetes DeamonSet 这种方式部署 Traefik,所以需要提前给节点设置 Label,这样当程序部署时 Pod 会自动调度到设置 Label 的节点上。

节点设置 Label 标签

  • 格式:kubectl label nodes [节点名] [key=value]
1$ kubectl label nodes k8s-node-2-12 IngressProxy=true

查看节点是否设置 Label 成功

1$ kubectl get nodes --show-labels
2
3NAME            STATUS ROLES  VERSION  LABELS
4k8s-master-2-11 Ready  master v1.15.3  kubernetes.io/hostname=k8s-master-2-11,node-role.kubernetes.io/master=
5k8s-node-2-12   Ready  <none> v1.15.3  kubernetes.io/hostname=k8s-node-2-12,IngressProxy=true
6k8s-node-2-13   Ready  <none> v1.15.3  kubernetes.io/hostname=k8s-node-2-13
7k8s-node-2-14   Ready  <none> v1.15.3  kubernetes.io/hostname=k8s-node-2-14

如果想删除标签,可以使用 kubectl label nodes k8s-node-2-12 IngressProxy- 命令

5、Kubernetes 部署 Traefik

这里还是按以前部署 Traefik 1.7 一样,用 DaemonSet 方式部署,便于在多服务器间扩展,用 hostport 方式占用服务器 80、443 端口,方便流量进入。

创建 traefik 部署文件 traefik-deploy.yaml

 1apiVersion: v1
 2kind: Service
 3metadata:
 4  name: traefik
 5spec:
 6  ports:
 7    - name: web
 8      port: 80
 9    - name: websecure
10      port: 443
11    - name: admin
12      port: 8080
13  selector:
14    app: traefik
15---
16apiVersion: apps/v1
17kind: DaemonSet
18metadata:
19  name: traefik-ingress-controller
20  labels:
21    app: traefik
22spec:
23  selector:
24    matchLabels:
25      app: traefik
26  template:
27    metadata:
28      name: traefik
29      labels:
30        app: traefik
31    spec:
32      serviceAccountName: traefik-ingress-controller
33      terminationGracePeriodSeconds: 1
34      containers:
35        - image: traefik:v2.0.5
36          name: traefik-ingress-lb
37          ports:
38            - name: web
39              containerPort: 80
40              hostPort: 80           #hostPort方式,将端口暴露到集群节点
41            - name: websecure
42              containerPort: 443
43              hostPort: 443          #hostPort方式,将端口暴露到集群节点
44            - name: admin
45              containerPort: 8080
46          resources:
47            limits:
48              cpu: 2000m
49              memory: 1024Mi
50            requests:
51              cpu: 1000m
52              memory: 1024Mi
53          securityContext:
54            capabilities:
55              drop:
56                - ALL
57              add:
58                - NET_BIND_SERVICE
59          args:
60            - --configfile=/config/traefik.yaml
61          volumeMounts:
62            - mountPath: "/config"
63              name: "config"
64      volumes:
65        - name: config
66          configMap:
67            name: traefik-config 
68      tolerations:              #设置容忍所有污点,防止节点被设置污点
69        - operator: "Exists"
70      nodeSelector:             #设置node筛选器,在特定label的节点上启动
71        IngressProxy: "true"

Kubernetes 部署 Traefik

1$ kubectl apply -f traefik-deploy.yaml -n kube-system

到此 Traefik v2.0 应用已经部署完成。

三、Traefik 路由规则配置

1、配置 HTTP 路由规则 (Traefik Dashboard 为例)

Traefik 应用已经部署完成,但是想让外部访问 Kubernetes 内部服务,还需要配置路由规则,这里开启了 Traefik Dashboard 配置,所以首先配置 Traefik Dashboard 看板的路由规则,使外部能够访问 Traefik Dashboard。

创建 Traefik Dashboard 路由规则文件 traefik-dashboard-route.yaml

 1apiVersion: traefik.containo.us/v1alpha1
 2kind: IngressRoute
 3metadata:
 4  name: traefik-dashboard-route
 5spec:
 6  entryPoints:
 7    - web
 8  routes:
 9    - match: Host(`traefik.mydlq.club`)
10      kind: Rule
11      services:
12        - name: traefik
13          port: 8080

创建 Traefik Dashboard 路由规则对象

1$ kubectl apply -f traefik-dashboard-route.yaml -n kube-system

接下来配置 Hosts,客户端想通过域名访问服务,必须要进行 DNS 解析,由于这里没有 DNS 服务器进行域名解析,所以修改 hosts 文件将 Traefik 指定节点的 IP 和自定义 host 绑定。打开电脑的 Hosts 配置文件,往其加入下面配置:

1192.168.2.12  traefik.mydlq.club

配置完成后,打开浏览器输入地址:http://traefik.mydlq.club 打开 Traefik Dashboard。

2、配置 HTTPS 路由规则(Kubernetes Dashboard 为例)

这里我们创建 Kubernetes 的 Dashboard 看板,它是 Https 协议方式,由于它是需要使用 Https 请求,所以我们配置基于 Https 的路由规则并指定证书。

创建证书文件

1# 创建自签名证书
2$ openssl req -x509 -nodes -days 3650 -newkey rsa:2048 -keyout tls.key -out tls.crt -subj "/CN=cloud.mydlq.club"
3
4# 将证书存储到 Kubernetes Secret 中
5$ kubectl create secret generic cloud-mydlq-tls --from-file=tls.crt --from-file=tls.key -n kube-system

创建 Traefik Dashboard 路由规则文件 kubernetes-dashboard-route.yaml

 1apiVersion: traefik.containo.us/v1alpha1
 2kind: IngressRoute
 3metadata:
 4  name: kubernetes-dashboard-route
 5spec:
 6  entryPoints:
 7    - websecure
 8  tls:
 9    secretName: cloud-mydlq-tls
10  routes:
11    - match: Host(`cloud.mydlq.club`) 
12      kind: Rule
13      services:
14        - name: kubernetes-dashboard
15          port: 443

创建 Kubernetes Dashboard 路由规则对象

1$ kubectl apply -f kubernetes-dashboard-route.yaml -n kube-system

跟上面一样,配置 Hosts 文件

1192.168.2.12  cloud.mydlq.club

配置完成后,打开浏览器输入地址:https://cloud.mydlq.club 打开 Dashboard Dashboard。

到此文章结束,可以访问我的 Github 下载 部署文件,别忘点颗 Start!!

---End---


  !版权声明:本博客内容均为原创,每篇博文作为知识积累,写博不易,转载请注明出处。