Kubernetes中根据Pod IP查找Pod及关联服务的实现方式

 更新时间:2025年10月02日 16:54:30   作者:XMYX-0  
文章介绍Kubernetes中通过Endpoints、Service选择器、网络策略及节点IPVS/iptables等方法快速定位Pod与关联Service的技巧,推荐优先使用Endpoints并结合标签匹配,适用于调试和运维场景

在 Kubernetes 集群中,有时候我们只知道 Pod 的 IP 地址,需要快速定位对应的 Pod 以及其关联的 Service。

这篇文章总结了几种可行的方法,并提供一些实用的诊断技巧。

方法一:通过 Endpoints 定位(推荐)

Kubernetes 的 Endpoints 对象保存了 Service 与 Pod IP 的映射关系,因此这是最直接的方法。

kubectl get endpoints --all-namespaces -o json | \
jq -r '.items[] | select(.subsets[].addresses[].ip == "10.255.111.149") | .metadata.namespace + "/" + .metadata.name'

注意:

  • 需要安装 jq 工具(apt-get install jqbrew install jq)。
  • 输出结果会显示 Pod 所属 Service 的命名空间和名称。

如果系统未安装 jq,也可以使用 jsonpath

kubectl get endpoints -A -o jsonpath='{range .items[?(@.subsets)]}{.metadata.namespace}{" "}{.metadata.name}{"\n"}{range .subsets[*].addresses[*]}{.ip}{"\n"}{end}{end}' | \
grep -B1 10.255.111.149

示例输出:

uat redis
10.255.111.149
  • uat: 命名空间
  • redis: Service 名称
  • 10.255.111.149: Pod IP 地址

方法二:通过 Service 的选择器(Selector)匹配

1、先找到 Pod 的标签:

kubectl get pod --all-namespaces -o wide --field-selector status.podIP=10.255.111.149

示例输出:

NAMESPACE   NAME                     READY   STATUS    RESTARTS   AGE    IP               NODE             NOMINATED NODE   READINESS GATES
uat         redis-5d57b8754f-ndlq7   1/1     Running   0          217d   10.255.111.149   10-255-101-210   <none>           <none>
  • NAMESPACE: 命名空间
  • NAME: Pod 名称
  • READY: Pod 状态
  • STATUS: Pod 运行状态
  • RESTARTS: 重启次数
  • AGE: Pod 存活时间
  • IP: Pod IP 地址
  • NODE: Pod 所在节点
  • NOMINATED NODE: 提名节点(无)
  • READINESS GATES: 就绪门(无)

2、根据标签查找对应的 Service:

kubectl get svc --all-namespaces -o json | \
jq -r '.items[] | select(.spec.selector.app == "myapp" and .spec.selector.env == "prod") | .metadata.namespace + "/" + .metadata.name'

注意:

  • 如果找不到服务,可能是 Pod 没有被任何 Service 选择,或者标签不匹配。
  • Service 的 Endpoints 只会包含处于 Ready 状态的 Pod。

方法三:检查网络策略(NetworkPolicy)

如果集群中启用了 NetworkPolicy,有时候需要确认 Pod 是否在某些策略范围内:

kubectl get networkpolicy --all-namespaces -o json | \
jq -r '.items[] | select(.spec.podSelector.matchLabels.app == "myapp") | .metadata.namespace + "/" + .metadata.name'

网络策略不会告诉你 Pod 关联的 Service,但可用于排查流量访问受限的原因。

方法四:通过节点 IPVS / iptables 直接查找(高级)

如果你想直接查看流量在节点上的转发情况,可以在运行 kube-proxy 的节点上使用:

sudo ipvsadm -Ln | grep -B1 10.255.111.149

说明:

  • 这种方法适合调试流量问题或者确认服务负载分发情况。
  • 对于 iptables 模式的 kube-proxy,可以使用 sudo iptables-save 查找 Pod IP。

额外诊断命令

  • 检查 Pod 就绪状态:
kubectl get pod -o wide -A | grep 10.255.111.149

输出示例:

uat                  redis-5d57b8754f-ndlq7                                            1/1     Running            0                       217d    10.255.111.149   10-255-101-210   <none>           <none>
  • 查看 Service 对应的 Endpoints:
kubectl describe svc <service-name> -n <namespace> | grep -A10 Endpoints
  • 测试网络连通性(在集群内节点执行):
curl -v http://10.255.111.149:<port>

总结与建议

  • 优先使用 Endpoints 方法:最直接、信息最全。
  • 结合 Pod 标签和 Service 选择器:可以快速排查标签不匹配问题。
  • 网络策略和节点工具:适合调试访问受限或流量异常场景。

诊断思路

  • Pod IP 确认 → Pod 就绪状态 → Service Endpoints → 网络策略 → 节点流量转发

通过这些方法,可以高效定位 Pod 及其关联服务,解决调试和运维中遇到的访问问题。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 节点NotReady后容器驱逐时间调整方式

    节点NotReady后容器驱逐时间调整方式

    文章介绍了Kubernetes早期版本中用于节点监控和Pod驱逐的参数,以及在k8s1.20版本后这些参数的废弃情况,通过测试,验证了新的TaintBasedEvictions机制的有效性,此外,还介绍了与Pod驱逐效率相关的kube-controller-manager参数,包括大规模集群的处理逻辑
    2026-01-01
  • Kubernetes应用服务质量管理详解

    Kubernetes应用服务质量管理详解

    这篇文章主要为大家介绍了Kubernetes应用服务质量管理详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • 在Kubernetes集群中搭建Istio微服务网格的过程详解

    在Kubernetes集群中搭建Istio微服务网格的过程详解

    这篇文章主要介绍了在Kubernetes集群中搭建Istio微服务网格,我们采用default配置档部署istio网格,istioctl install命令不指定任何配置档默认就是呀default配置档,需要的朋友可以参考下
    2022-05-05
  • k8s部署dashboard ui管理平台全过程

    k8s部署dashboard ui管理平台全过程

    Kubernetes仪表盘是一个用于管理和监控Kubernetes集群的Web界面,它是一个容器化应用,可以通过Kubernetes的API进行部署和管理,仪表盘提供了一个用户友好的界面,可以查看和管理集群中的资源,包括Pod、Deployment、Service等
    2026-01-01
  • 阿里云kubernetes查找镜像中jar包的方法(docker查看镜像中的jar)

    阿里云kubernetes查找镜像中jar包的方法(docker查看镜像中的jar)

    这篇文章主要给大家介绍了关于阿里云kubernetes查找镜像中jar包的方法,也就是在docker查看镜像中的jar,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2022-09-09
  • K8s Pod容器中的command和args指令详解

    K8s Pod容器中的command和args指令详解

    这篇文章主要介绍了K8s新手系列之Pod容器中的command和args指令的相关资料,本文给大家介绍的非常详细,感兴趣的朋友一起看看吧
    2025-05-05
  • kubernetes Volume存储卷configMap学习笔记

    kubernetes Volume存储卷configMap学习笔记

    这篇文章主要为大家介绍了kubernetes Volume存储卷configMap学习笔记,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05
  • Spark实现K-Means算法代码示例

    Spark实现K-Means算法代码示例

    这篇文章主要介绍了Spark实现K-Means算法代码示例,简单介绍了K-Means算法及其原理,然后通过具体实例向大家展示了用spark实现K-Means算法,需要的朋友可以参考下。
    2017-10-10
  • k8s设置非强一致反亲和性示例

    k8s设置非强一致反亲和性示例

    这篇文章主要为大家介绍了k8s设置非强一致反亲和性示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-10-10
  • OSS获取阿里云的bucket和endpoint实现方式

    OSS获取阿里云的bucket和endpoint实现方式

    本文介绍了获取阿里云OSS的bucket和endpoint的方法,这两个参数决定了文件的最终访问地址,bucket是OSS项目名称,endpoint是存储服务器位置,此外,还提到了OSS的文件管理与域名管理功能
    2026-03-03

最新评论