JSONPath 支持

kubectl 支持 JSONPath 模板。

JSONPath 模板由 {} 包起来的 JSONPath 表达式组成。Kubectl 使用 JSONPath 表达式来过滤 JSON 对象中的特定字段并格式化输出。 除了原始的 JSONPath 模板语法,以下函数和语法也是有效的:

  1. 使用双引号将 JSONPath 表达式内的文本引起来。
  2. 使用 rangeend 运算符来迭代列表。
  3. 使用负片索引后退列表。负索引不会“环绕”列表,并且只要 -index + listLength> = 0 就有效。

说明:

  • $ 运算符是可选的,因为默认情况下表达式总是从根对象开始。

  • 结果对象将作为其 String() 函数输出。

给定 JSON 输入:

  1. {
  2. "kind": "List",
  3. "items":[
  4. {
  5. "kind":"None",
  6. "metadata":{
  7. "name":"127.0.0.1",
  8. "labels":{
  9. "kubernetes.io/hostname":"127.0.0.1"
  10. }
  11. },
  12. "status":{
  13. "capacity":{"cpu":"4"},
  14. "addresses":[{"type": "LegacyHostIP", "address":"127.0.0.1"}]
  15. }
  16. },
  17. {
  18. "kind":"None",
  19. "metadata":{"name":"127.0.0.2"},
  20. "status":{
  21. "capacity":{"cpu":"8"},
  22. "addresses":[
  23. {"type": "LegacyHostIP", "address":"127.0.0.2"},
  24. {"type": "another", "address":"127.0.0.3"}
  25. ]
  26. }
  27. }
  28. ],
  29. "users":[
  30. {
  31. "name": "myself",
  32. "user": {}
  33. },
  34. {
  35. "name": "e2e",
  36. "user": {"username": "admin", "password": "secret"}
  37. }
  38. ]
  39. }
函数描述示例结果
text纯文本kind is {.kind}kind is List
@当前对象{@}与输入相同
.[]子运算符{.kind}{[‘kind’]}{[‘name.type’]}List
..递归下降{..name}127.0.0.1 127.0.0.2 myself e2e
通配符。获取所有对象{.items[].metadata.name}[127.0.0.1 127.0.0.2]
[start:end:step]下标运算符{.users[0].name}myself
[,]并集运算符{.items[][‘metadata.name’, ‘status.capacity’]}127.0.0.1 127.0.0.2 map[cpu:4] map[cpu:8]
?()过滤{.users[?(@.name==”e2e”)].user.password}secret
rangeend迭代列表{range .items[]}[{.metadata.name}, {.status.capacity}] {end}[127.0.0.1, map[cpu:4]] [127.0.0.2, map[cpu:8]]
‘’引用解释执行字符串{range .items[*]}{.metadata.name}{‘\t’}{end}127.0.0.1 127.0.0.2
\转义终止符{.items[0].metadata.labels.kubernetes.io/hostname}127.0.0.1

使用 kubectl 和 JSONPath 表达式的示例:

  1. kubectl get pods -o json
  2. kubectl get pods -o=jsonpath='{@}'
  3. kubectl get pods -o=jsonpath='{.items[0]}'
  4. kubectl get pods -o=jsonpath='{.items[0].metadata.name}'
  5. kubectl get pods -o=jsonpath="{.items[*]['metadata.name', 'status.capacity']}"
  6. kubectl get pods -o=jsonpath='{range .items[*]}{.metadata.name}{"\t"}{.status.startTime}{"\n"}{end}'
  7. kubectl get pods -o=jsonpath='{.items[0].metadata.labels.kubernetes\.io/hostname}'

说明:

在 Windows 上,对于任何包含空格的 JSONPath 模板,你必须使用双引号(不是上面 bash 所示的单引号)。 反过来,这意味着你必须在模板中的所有文字周围使用单引号或转义的双引号。例如:

  1. C:\> kubectl get pods -o=jsonpath="{range .items[*]}{.metadata.name}{'\t'}{.status.startTime}{'\n'}{end}"
  2. C:\> kubectl get pods -o=jsonpath="{range .items[*]}{.metadata.name}{\"\t\"}{.status.startTime}{\"\n\"}{end}"

说明:

不支持 JSONPath 正则表达式。如需使用正则表达式进行匹配操作,你可以使用如 jq 之类的工具。

  1. # kubectl 的 JSONpath 输出不支持正则表达式
  2. # 下面的命令不会生效
  3. kubectl get pods -o jsonpath='{.items[?(@.metadata.name=~/^test$/)].metadata.name}'
  4. # 下面的命令可以获得所需的结果
  5. kubectl get pods -o json | jq -r '.items[] | select(.metadata.name | test("test-")).metadata.name'