Kubernetes NodePort 没有监听
Kubernetes NodePort not listening
我正在使用 k3d(docker 中的 k3s)做一些教程,我的 yml 如下所示:
apiVersion: apps/v1
kind: Deployment
metadata:
name: nginx
labels:
app: nginx
spec:
selector:
matchLabels:
app: nginx
template:
metadata:
labels:
app: nginx
spec:
containers:
- name: nginx
image: nginx:alpine
ports:
- containerPort: 80
---
apiVersion: v1
kind: Service
metadata:
name: nginx
labels:
app: nginx
spec:
type: NodePort
selector:
app: nginx
ports:
- name: http
port: 80
targetPort: 80
生成的节点端口为 31747:
:~$ kubectl get service
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
kubernetes ClusterIP 10.43.0.1 <none> 443/TCP 18m
nginx NodePort 10.43.254.138 <none> 80:31747/TCP 17m
:~$ kubectl get endpoints
NAME ENDPOINTS AGE
kubernetes 172.18.0.2:6443 22m
nginx 10.42.0.8:80 21m
但是 wget 不起作用:
:~$ wget localhost:31747
Connecting to localhost:31747 ([::1]:31747)
wget: can't connect to remote host: Connection refused
:~$
我错过了什么?我确保我的标签都写着 app: nginx
而我的 containerPort
、port
和 targetPort
都是 80
问题是,NodePort 范围是否从主机映射到充当节点的 docker 容器。命令 docker ps
将向您显示,有关更多详细信息,您可以 docker inspect $container_id
并查看 NetworkSettings
下的 Ports
属性。我周围没有 k3d,但这里有一个来自 kind 的例子。
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
1d2225b83a73 kindest/node:v1.17.0 "/usr/local/bin/entr…" 18 hours ago Up 18 hours 127.0.0.1:32769->6443/tcp kind-control-plane
$ docker inspect kind-control-plane
[
{
# [...]
"NetworkSettings": {
# [...]
"Ports": {
"6443/tcp": [
{
"HostIp": "127.0.0.1",
"HostPort": "32769"
}
]
},
# [...]
}
]
如果不是,按照评论中的建议使用 kubectl port-forward
可能是最简单的方法。或者,开始研究 Ingress。 Ingress 是在集群外部公开工作负载的首选方法,在这种情况下,they have support for Ingress. It seems k3d also has a way to map the ingress port to the host.
原来我在创建集群的时候没有暴露端口
也许,您的 pod 运行 在另一个工作节点上,而不是本地主机上。你应该使用正确的节点 ip。
我正在使用 k3d(docker 中的 k3s)做一些教程,我的 yml 如下所示:
apiVersion: apps/v1
kind: Deployment
metadata:
name: nginx
labels:
app: nginx
spec:
selector:
matchLabels:
app: nginx
template:
metadata:
labels:
app: nginx
spec:
containers:
- name: nginx
image: nginx:alpine
ports:
- containerPort: 80
---
apiVersion: v1
kind: Service
metadata:
name: nginx
labels:
app: nginx
spec:
type: NodePort
selector:
app: nginx
ports:
- name: http
port: 80
targetPort: 80
生成的节点端口为 31747:
:~$ kubectl get service
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
kubernetes ClusterIP 10.43.0.1 <none> 443/TCP 18m
nginx NodePort 10.43.254.138 <none> 80:31747/TCP 17m
:~$ kubectl get endpoints
NAME ENDPOINTS AGE
kubernetes 172.18.0.2:6443 22m
nginx 10.42.0.8:80 21m
但是 wget 不起作用:
:~$ wget localhost:31747
Connecting to localhost:31747 ([::1]:31747)
wget: can't connect to remote host: Connection refused
:~$
我错过了什么?我确保我的标签都写着 app: nginx
而我的 containerPort
、port
和 targetPort
都是 80
问题是,NodePort 范围是否从主机映射到充当节点的 docker 容器。命令 docker ps
将向您显示,有关更多详细信息,您可以 docker inspect $container_id
并查看 NetworkSettings
下的 Ports
属性。我周围没有 k3d,但这里有一个来自 kind 的例子。
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
1d2225b83a73 kindest/node:v1.17.0 "/usr/local/bin/entr…" 18 hours ago Up 18 hours 127.0.0.1:32769->6443/tcp kind-control-plane
$ docker inspect kind-control-plane
[
{
# [...]
"NetworkSettings": {
# [...]
"Ports": {
"6443/tcp": [
{
"HostIp": "127.0.0.1",
"HostPort": "32769"
}
]
},
# [...]
}
]
如果不是,按照评论中的建议使用 kubectl port-forward
可能是最简单的方法。或者,开始研究 Ingress。 Ingress 是在集群外部公开工作负载的首选方法,在这种情况下,they have support for Ingress. It seems k3d also has a way to map the ingress port to the host.
原来我在创建集群的时候没有暴露端口
也许,您的 pod 运行 在另一个工作节点上,而不是本地主机上。你应该使用正确的节点 ip。