当我们在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在运行完所有的豆荚和服务之后,我做了kubectl proxy,它说:
Starting to serve on 127.0.0.1:8001所以,当我想访问这个服务时,比如:
curl localhost:8001/api/它在集群内是可以到达的!如何才能到达集群之外的服务?
发布于 2018-12-09 16:20:07
您应该使用NodePort公开服务:
apiVersion: v1
kind: Service
metadata:
name: neo4j
labels:
app: neo4j
component: core
spec:
externalTrafficPolicy: Local
type: NodePort
ports:
- port: 7474
targetPort: 7474
name: browser
- port: 6362
targetPort: 6362
name: backup
selector:
app: neo4j
component: core现在,如果您使用
kubectl describe svc neo4j您将获得一个nodeport值,该值在30000-32767之间,您可以使用
curl http://<node_ip>:<node_port>希望这能有所帮助。
编辑:是的,在通过clusterIP: None公开服务的情况下,您不能直接使用NodePort。现在,clusterIP: None意味着没有由kubernetes完成的内部负载平衡,为此,我们也可以在服务定义中使用externalTrafficPolicy=Local。
或者,您可以使用入口将流量路由到正确的服务。
https://stackoverflow.com/questions/53693030
复制相似问题