Kubernetes 中 LoadBalancer 无外部 IP 如何访问后端服务?

kubernetes 中 loadbalancer 无外部 ip 如何访问后端服务?

k8s 无外部 ip 的 loadbalancer 服务访问

在本例中,您创建了一个 loadbalancer 类型的服务,但没有外部 ip。您希望通过该服务访问后端的三个 nginx 容器。

无法通过容器内部访问外部互联网

您提到的 nginx 容器无法解析外部域名,因为它们配置为使用节点的 dns 配置。要解决此问题,请检查 coredns 配置,确保上游 dns 服务器已正确配置,以便可以解析外部域名。

访问 loadbalancer 服务的方法:

  1. 创建 nodeport 类型的服务:创建一个 nodeport 类型的服务,它将自动将一个端口号暴露在每个节点上。这将允许您通过节点 ip 和端口访问服务。
  2. 修改 loadbalancer 类型的服务为 nodeport:将现有的 loadbalancer 类型的服务编辑为 nodeport 类型的服务。
  3. 使用 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 如何访问后端服务?的详细内容,更多请关注硕下网其它相关文章!