# 字段选择器

# 概述

字段选择器(Field Selector)可以用来基于的一个或多个字段的取值来选取一组Kubernetes对象。下面有一些示例性的字段选择器:

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

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

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

TIP

字段选择器本质上是一个 filter。默认情况下,没有添加 selector/filter 时,代表着指定资源类型的所有对象都被选中。下面个两个 kubectl 查询时等价的:

kubectl get pods
kubectl get pods --field-selector ""
1
2

# 支持的字段

不同的 Kubernetes 对象类型,可以用来查询的字段不一样。所有的对象类型都支持的两个字段是 metadata.namemetadata.namespace。在字段选择器中使用不支持的字段,将报错。例如:

kubectl get ingress --field-selector foo.bar=baz
1

输出结果为:

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"
1

# 支持的操作符

字段选择器中可以使用的操作符有 ===!==== 含义相同)。例如,下面的 kubectl 命令,查询不在 default 名称空间中的 Service:

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

# 多选择器

可以指定多个字段选择器,用逗号 , 分隔。下面的 kubectl 命令查询所有的 status.phase 不等于 Runningspec.restartPolicy 等于 Always 的 Pod:

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

# 多种对象类型

字段选择器可以跨资源类型使用。下面的 kubectl 命令查询所有的不在 default 名称空间的 StatefulSet 和 Service:

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