Kubernetes(k8s)中命令行查看Pod所属控制器之方法总结

在Kubernetes中,可以通过以下方法查看Pod所属的控制器:

方法1:使用 kubectl describe pod命令

复制代码
kubectl describe pod <pod name>

Events:
  Type    Reason     Age   From               Message
  ----    ------     ----  ----               -------
  Normal  Scheduled  10m   default-scheduler  Successfully assigned default/nginx-pod to node-1
  Normal  Pulling    9m59s  kubelet            Pulling image "nginx:1.17.1"
  ...
  # 控制器信息可能显示在此处

方法2:通过Pod的元数据(YAML格式)

复制代码
kubectl get pod <pod name> -o yaml

在输出中查找 ownerReferences部分,会明确标注控制器类型和名称:

复制代码
metadata:
  ownerReferences:
  - apiVersion: apps/v1
    kind: Deployment   # 控制器类型
    name: Web-deploy # 控制器名称
    uid: xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
    controller: true
    blockOwnerDeletion: true

方法3:通过标签匹配

Pod的标签(Labels)会与控制器的标签选择器(Selector)匹配。例如:

1)查看Pod的标签:

复制代码
kubectl get pod <pod名称> --show-labels

2)根据标签查找对应的控制器(以Deployment为例)

复制代码
kubectl get deployments.apps -l <pod的标签键>=<标签值>

方法4:使用 kubectl api-resourceskubectl get 组合查询

如果你不确定 Pod 是由哪种类型的控制器管理的,可以先列出所有支持的资源类型:

复制代码
kubectl api-resources --namespaced=true  

然后,你可以根据输出的资源类型(如 Deployment, StatefulSet 等),使用以下命令来查找管理特定 Pod 的控制器:

复制代码
kubectl get deployments --all-namespaces -o wide | grep <pod-name>

或者对于其他类型的控制器,如 StatefulSet:

复制代码
kubectl get statefulsets --all-namespaces -o wide | grep <pod-name>

补充说明:

  • Deployment管理的Pod​ ​:会显示 Deployment类型,并通过 ReplicaSet间接管理

  • StatefulSet管理的Pod​ ​:名称通常包含序号(如 web-0),且通过Headless Service关联

  • ​DaemonSet管理的Pod​ ​:每个节点运行一个Pod,可通过 kubectl get daemonset

  • 如果Pod无控制器(如自主式Pod),则 ownerReferences字段为空。

相关推荐
!chen9 小时前
k8s-Pod中的网络通信
网络·docker·kubernetes
熙客12 小时前
Kubernetes是如何保证有状态应用数据安全和快速恢复的
mysql·云原生·容器·kubernetes
似水流年 光阴已逝14 小时前
Kubernetes Pod 基本原理:全面详解
云原生·容器·kubernetes·pod
高旭博18 小时前
10. kubernetes资源——statefulset有状态负载
云原生·容器·kubernetes
_Walli_18 小时前
k8s集群搭建(七)-------- 微服务间的调用
微服务·容器·kubernetes
马达加斯加D19 小时前
k8s --- resource: Pod, ReplicaSet and Deployment
云原生·容器·kubernetes
zmjjdank1ng1 天前
k8s问答题(二)
云原生·容器·kubernetes
小坏讲微服务2 天前
五分钟使用 Docker-compose搭建 Redis 8.0 中间件
运维·redis·docker·中间件·容器·kubernetes·k8s
wuk9982 天前
基于开源操作系统搭建K8S高可用集群
容器·kubernetes·开源
稚辉君.MCA_P8_Java2 天前
深入理解 TCP;场景复现,掌握鲜为人知的细节
java·linux·网络·tcp/ip·kubernetes