上一篇讲解deployment方式部署ingress。
使用DaemonSet方式部署ingress。
官方原始文件使用的是deployment,replicate 为 1,这样将会在某一台节点上启动对应的nginx-ingress-controller pod。外部流量访问至该节点,由该节点负载分担至内部的service。测试环境考虑防止单点故障,改为DaemonSet然后删掉replicate ,配合亲和性部署在制定节点上启动nginx-ingress-controller pod,确保有多个节点启动nginx-ingress-controller pod,后续将这些节点加入到外部硬件负载均衡组实现高可用性。
1. 添加hostNetwork
true:添加该字段,暴露nginx-ingress-controller pod的服务端口(80)
2. 添加亲和性属性
增加亲和性部署,有 isIngress 标签的节点才会部署该DaemonSet
3. 设置节点的label
[root@master01 ~]# kubectl label nodes node01 isIngress=true
node/node01 labeled
[root@master01 ~]# kubectl label nodes node02 isIngress=true
node/node02 labeled
[root@master01 ~]# kubectl label nodes node03 isIngress=true
node/node03 labeled
4. 执行并部署ingress
cat mandatory-ds.yaml
apiVersion: v1
kind: Namespace #新增空间命名ingress-nginx
metadata:
name: ingress-nginx
labels:
app.kubernetes.io/name: ingress-nginx
app.kubernetes.io/part-of: ingress-nginx
---
kind: ConfigMap
apiVersion: v1
metadata:
name: nginx-configuration
namespace: ingress-nginx
labels:
app.kubernetes.io/name: ingress-nginx
app.kubernetes.io/part-of: ingress-nginx
---
kind: ConfigMap
apiVersion: v1
metadata:
name: tcp-services
namespace: ingress-nginx
labels:
app.kubernetes.io/name: ingress-nginx
app.kubernetes.io/part-of: ingress-nginx
---
kind: ConfigMap
apiVersion: