K8S中nodePort、port和 targetPort的区别

在Kubernetes Service的配置中,nodePortporttargetPort承担着不同的网络流量转发角色。简单来说:

  • port :Service在集群内部的访问端口,其他服务通过<ClusterIP>:<port>访问该Service。

  • targetPort:Service将流量转发到的Pod上的实际端口,必须与Pod内容器监听的端口一致。

  • nodePort :在集群每个节点上开放的端口,允许外部客户端通过<任意节点IP>:<nodePort>访问Service。

下面这个表格更清晰地展示了它们的区别:

端口类型 作用层级 主要用途 访问方式示例 是否必选
port Service 集群内部虚拟IP 集群内服务间通信 10.96.123.456:80(ClusterIP:port)
targetPort Pod/容器 指定流量最终到达容器的端口 由Service自动转发,通常不直接访问 否,默认与port相同
nodePort 集群节点(Node) 从集群外部访问服务 http://<节点IP>:32556 否,仅NodePort/LoadBalancer类型需要

端口协作流程

当有一个外部请求到来时,这些端口会按照一条清晰的路径协作,最终将流量送达正确的容器:

外部请求 → nodePort(节点IP上的端口) → port(Service的端口) → targetPort(Pod内容器的端口)

例如,service配置(nodePort: 32556, port: 13000, targetPort: 13000):

  • 外部用户通过浏览器访问 http://<任意节点IP>:32556

  • 该节点的kube-proxy接收到请求,并根据Service规则将其转发到Service的ClusterIP上的13000端口。

  • Service的负载均衡机制将请求路由到某个健康Pod的13000端口,最终被Pod内运行的应用程序处理。

配置要点与示例

  1. targetPort的灵活性targetPort可以是数字,也可以是Pod定义中命名的端口,这增加了配置的灵活性和可读性。例如,在Pod模板中,您可以定义 name: http,然后在Service中设置 targetPort: http

  2. 端口映射无需一致 :这三个端口的编号不需要相同。一个常见的场景是,让Service在80端口(port: 80)对外提供HTTP服务,而实际的应用容器在8080端口(targetPort: 8080)进行监听。

  3. containerPort的角色 :在Pod的YAML定义中,还有一个containerPort字段。它主要用于声明容器会监听哪个端口,起​ informational(告知性)作用。即使不设置,只要容器进程确实在该端口监听,Service也能将流量转发过去。通常建议设置,以明确容器的网络契约。

注意事项

  • nodePort端口范围 :如果您不显式指定nodePort,Kubernetes会在30000-32767范围内自动分配一个。如果您需要指定,则必须在此范围内。

  • 生产环境考虑 :虽然NodePort类型很方便,但对于高可用的生产环境,通常建议使用更高级的入口方式,如Ingress,它能提供基于域名和路径的路由、SSL终止等更强大的功能。

相关推荐
爱喝矿泉水的猛男5 小时前
MacOS彻底清除docker及image
运维·docker·容器
CNRio5 小时前
软件架构趋势:云原生与大模型的融合与重塑
云原生
~kiss~6 小时前
Milvus-云原生和分布式的开源向量数据库-介绍
分布式·云原生·milvus
王煜苏6 小时前
最新版idea2025 配置docker 打包spring-boot项目到生产服务器全流程,含期间遇到的坑
java·docker·容器
给算法爸爸上香6 小时前
模型部署在docker中对外提供服务
docker·容器·模型部署·模型推理
小坏讲微服务8 小时前
整合Spring Cloud Alibaba与Gateway实现跨域的解决方案
java·开发语言·后端·spring cloud·云原生·gateway
q***97918 小时前
从零到上线:Node.js 项目的完整部署流程(包含 Docker 和 CICD)
docker·容器·node.js
早睡冠军候选人12 小时前
Ansible学习----管理复杂的 Play 和 Playbook 内容
运维·学习·云原生·ansible