我正在尝试在带有Helm的Kubernetes上部署一个nginx-ingress控制器。
我还想配置它以将nginx-ingress-controller服务的特定端口绑定到VM上的特定节点端口[我在Vagrant中运行它。]
例如,我想要:
10000节点端口-> 8080 nginx入口控制器->我的后端服务的10000 udp端口
我的Helm部署如下:
release_name=tcp-udp-nginx-ic
http_nodePort=30080
https_nodePort=30443
echo
echo "- Installing -${release_name}- into cluster ..." | cowsay
helm del --purge ${release_name}
helm upgrade --install ${release_name} \
--set controller.service.type=NodePort \
--set controller.service.nodePorts.http=${http_nodePort} \
--set controller.service.nodePorts.https=${https_nodePort} \
--set rbac.create=true \
--set controller.replicaCount=1 \
--set controller.resources.requests."memory"=300Mi \
--set controller.resources.requests."cpu"=300m \
--set controller.resources.limits."memory"=300Mi \
--set controller.resources.limits."cpu"=300m \
--set controller.ingressClass=nginx \
--set controller.tcp.configMapNamespace=default \
--set controller.udp.configMapNamespace=default \
--set udp."8080"="default/the-backend-service:10000" \
--set service.nodePorts.udp."8080"=10000 \
stable/nginx-ingress
我的问题是,为了完成上述操作,我应该以什么格式输入--set service.nodePorts.udp
部分?
关于limitations of --set的Helm文档中引用了我使用的格式。
我知道我已经接近了,因为当我在本地克隆图表并在values.yml
文件中设置以下内容时,效果很好。
nodePorts:
http: ""
https: ""
tcp: {}
# udp: {}
udp:
8080: 10000
8081: 10001
当我像这样部署它并desscribe
部署入口控制器服务时,我会得到:
Name: tcp-udp-nginx-ic-nginx-ingress-controller
Namespace: default
Labels: app=nginx-ingress
chart=nginx-ingress-1.24.3
component=controller
heritage=Tiller
release=tcp-udp-nginx-ic
Annotations: <none>
Selector: app=nginx-ingress,component=controller,release=tcp-udp-nginx-ic
Type: NodePort
IP: 10.109.1.182
Port: http 80/TCP
TargetPort: http/TCP
NodePort: http 30080/TCP
Endpoints:
Port: https 443/TCP
TargetPort: https/TCP
NodePort: https 30443/TCP
Endpoints:
Port: 8080-udp 8080/UDP
TargetPort: 8080-udp/UDP
NodePort: 8080-udp 10000/UDP
Endpoints:
Session Affinity: None
External Traffic Policy: Cluster
Events: <none>