我想在 AWS EKS 上为从外部系统访问的多个微服务设置一个入口控制器。
微服务通过虚拟主机名访问,如svc1.acme.com
, svc2.acme.com
, ...
我使用 helm 图表设置了 nginx 入口控制器:https ://github.com/helm/charts/tree/master/stable/nginx-ingress
我的想法是保留一个弹性 IP 地址并通过设置变量 externalIP 将 nginx 控制器绑定到该 IP。
这样我应该能够使用稳定的通配符 DNS 条目访问服务*.acme.com --> 54.72.43.19
我可以看到入口控制器服务获取了外部IP,但该IP不可访问。
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
ingress-nginx-ingress-controller LoadBalancer 10.100.45.119 54.72.43.19 80:32104/TCP,443:31771/TCP 1m
知道为什么吗?
更新:
我使用以下命令安装了入口控制器:
helm install --name ingress -f values.yaml stable/nginx-ingress
这是值的要点,唯一与默认值不同的是
externalIPs: ["54.72.43.19"]
https://gist.github.com/christianwoehrle/3b136023b1e0085b028a67ca6a0959b7