Kubernetes 中 LoadBalancer 无外部 IP 如何访问后端服务?
k8s 无外部 ip 的 loadbalancer 服务访问
在本例中,您创建了一个 loadbalancer 类型的服务,但没有外部 ip。您希望通过该服务访问后端的三个 nginx 容器。
无法通过容器内部访问外部互联网
您提到的 nginx 容器无法解析外部域名,因为它们配置为使用节点的 dns 配置。要解决此问题,请检查 coredns 配置,确保上游 dns 服务器已正确配置,以便可以解析外部域名。
访问 loadbalancer 服务的方法:
- 创建 nodeport 类型的服务:创建一个 nodeport 类型的服务,它将自动将一个端口号暴露在每个节点上。这将允许您通过节点 ip 和端口访问服务。
- 修改 loadbalancer 类型的服务为 nodeport:将现有的 loadbalancer 类型的服务编辑为 nodeport 类型的服务。
- 使用 metallb 负载均衡器:metallb 是一个用于在 kubernetes 集群中提供负载均衡服务的开源工具。它可以自动为 loadbalancer 类型的服务分配外部 ip 地址。
解析示例:
apiversion: v1 kind: service metadata: name: my-nginx-svc labels: app: nginx spec: type: nodeport ports: - port: 80 # 设置 nodeport 端口号 nodeport: 30080 selector: app: nginx
现在,您应该可以通过节点 ip 和端口 30080 访问 nginx 服务。例如:
curl http://<node-ip>:30080
以上就是Kubernetes 中 LoadBalancer 无外部 IP 如何访问后端服务?的详细内容,更多请关注硕下网其它相关文章!