kubernetes-负载均衡器外部端点始终是localhost

问题描述

我正在使用minikube,当我创建一个负载平衡器时,它总是会在外部端点上为我提供不同的IP,并且能够访问我的应用程序。

但是现在,我改为使用docker kubernetes,并且在创建负载均衡器时,它总是在外部端点上添加localhost:8181

这是我的Yaml:

apiVersion: v1
kind: Service
Metadata:
  name: app1
  labels:
    app: app1
spec:
  #externalIPs:
  #  - 172.29.0.0
  ports:
  - protocol: TCP
    name: http
    port: 8181
    targetPort: 8181
  type: LoadBalancer
  selector:
    app: app1

与:kubectl expose deployment app1 --port=8181 --target-port=8181 --name=app1 --type=LoadBalancer

相同

如您所见,我尝试添加externalIP,这样做时,本地主机和externalIP都出现在仪表板中,但是使用externalIP无效...

创建负载均衡器时,我希望它生成一个ip,以便可以像从minikube一样从那里访问我的应用程序。

感谢您的时间。

解决方法

Official documentation说:

类型值及其行为为: LoadBalancer:使用云提供商的负载平衡器从外部公开服务。自动创建外部负载均衡器路由到的NodePort和ClusterIP服务。

这就是为什么使用Kubernetes必须启用云提供商(否则将不提供外部IP)的原因:

$ kubectl get svc
NAME                     TYPE           CLUSTER-IP    EXTERNAL-IP   PORT(S)          AGE
app1                     LoadBalancer   10.0.2.46     <pending>     8181:30257/TCP   18s

在minikube中,它是通过minikube service <service_name>为您提供的:

$ kubectl get svc
NAME         TYPE           CLUSTER-IP     EXTERNAL-IP   PORT(S)          AGE
app1         LoadBalancer   10.103.51.13   <pending>     8181:30129/TCP   68s

$ minikube service app1
|-----------|------|-------------|-----------------------------|
| NAMESPACE | NAME | TARGET PORT |             URL             |
|-----------|------|-------------|-----------------------------|
| default   | app1 | http/8181   | http://192.168.99.100:30129 |
|-----------|------|-------------|-----------------------------|

创建负载均衡器时,我希望它生成一个ip,以便可以像从minikube一样从那里访问我的应用程序。

Ales Nosek的主题为awesome post

简而言之:

为了能够创建LoadBalancer类型的服务,必须在Kubernetes集群的配置中启用云提供商。从1.6版开始,Kubernetes可以在AWS,Azure,CloudStack,GCE和OpenStack上配置负载均衡器。

这在很大程度上取决于您想要实现的目标,但是我相信您可能对Ingress感兴趣。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...