字段选择器

字段选择器允许你根据一个或多个资源字段的值来选择 Kubernetes 对象。以下是一些字段选择器查询示例:

  • metadata.name=my-service
  • metadata.namespace!=default
  • status.phase=Pending

kubectl 命令选择所有 status.phase 字段值为 Running 的 Pod:

kubectl get pods --field-selector status.phase=Running

支持的字段

支持的字段选择器因 Kubernetes 资源类型而异。所有资源类型都支持 metadata.namemetadata.namespace 字段。使用不支持的字段选择器会产生错误。例如:

kubectl get ingress --field-selector foo.bar=baz
Error from server (BadRequest): Unable to find "ingresses" that match label selector "", field selector "foo.bar=baz": "foo.bar" is not a known field selector: only "metadata.name", "metadata.namespace"

支持的字段列表

类型字段
Podspec.nodeName
spec.restartPolicy
spec.schedulerName
spec.serviceAccountName
spec.hostNetwork
status.phase
status.podIP
status.nominatedNodeName
EventinvolvedObject.kind
involvedObject.namespace
involvedObject.name
involvedObject.uid
involvedObject.apiVersion
involvedObject.resourceVersion
involvedObject.fieldPath
reason
reportingComponent
source
type
Secrettype
Namespacestatus.phase
副本集status.replicas
复制控制器status.replicas
作业status.successful
Nodespec.unschedulable
CertificateSigningRequestspec.signerName

自定义资源字段

所有自定义资源类型都支持 metadata.namemetadata.namespace 字段。

此外,CustomResourceDefinitionspec.versions[*].selectableFields 字段声明了自定义资源中哪些其他字段可以用于字段选择器。有关如何将字段选择器与 CustomResourceDefinitions 一起使用的更多信息,请参阅自定义资源的可选字段

支持的操作符

你可以使用 ===!= 操作符与字段选择器(=== 含义相同)。例如,此 kubectl 命令选择所有不在 default 命名空间中的 Kubernetes Service:

kubectl get services  --all-namespaces --field-selector metadata.namespace!=default

链式选择器

标签和其他选择器一样,字段选择器可以作为逗号分隔列表进行链接。此 kubectl 命令选择所有 status.phase 不等于 Runningspec.restartPolicy 字段等于 Always 的 Pod:

kubectl get pods --field-selector=status.phase!=Running,spec.restartPolicy=Always

多种资源类型

你可以在多种资源类型上使用字段选择器。此 kubectl 命令选择所有不在 default 命名空间中的 Statefulset 和 Service:

kubectl get statefulsets,services --all-namespaces --field-selector metadata.namespace!=default
上次修改时间:2024 年 10 月 31 日太平洋标准时间上午 10:47:删除稳定功能的字段门信息,向字段选择器文档添加详细信息 (2b996e4434)