当我们在kubernetes中使用kubeadm启动集群时,服务的 .yaml
文件如下所示:
apiVersion: v1
kind: Service
metadata:
name: neo4j
labels:
app: neo4j
component: core
spec:
clusterIP: None
ports:
- port: 7474
targetPort: 7474
name: browser
- port: 6362
targetPort: 6362
name: backup
selector:
app: neo4j
component: core
在所有pod和服务运行之后,我做 kubectl proxy
并且它说:
Starting to serve on 127.0.0.1:8001
所以当我想要访问这样的服务时:
curl localhost:8001/api/
它只能在集群内部到达!如何访问群集外的服务?
1 回答
您应该使用NodePort公开您的服务:
现在,如果您使用了描述您的服务
您将获得一个在30000-32767之间的nodeport值,您可以使用从群集外部访问您的服务
希望这可以帮助 .
编辑:是的,如果通过NodePort公开服务,你不能直接使用
clusterIP: None
. 现在clusterIP: None
意味着kubernetes没有内部负载 balancer ,为此我们也可以在服务定义中使用externalTrafficPolicy=Local
.或者,您可以使用入口将流量路由到正确的服务 .