JSONPath 支持

Kubectl 支持 JSONPath 模板。

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

  • 使用双引号将 JSONPath 表达式内的文本引起来。
  • 使用 rangeend 运算符来迭代列表。
  • 使用负片索引后退列表。负索引不会”环绕”列表,并且只要 -index + listLength> = 0 就有效。
注意:
  • $ 运算符是可选的,因为默认情况下表达式总是从根对象开始。

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

给定 JSON 输入:

  1. {
  2. "kind": "List",
  3. "items":[
  4. {
  5. "kind":"None",
  6. "metadata":{"name":"127.0.0.1"},
  7. "status":{
  8. "capacity":{"cpu":"4"},
  9. "addresses":[{"type": "LegacyHostIP", "address":"127.0.0.1"}]
  10. }
  11. },
  12. {
  13. "kind":"None",
  14. "metadata":{"name":"127.0.0.2"},
  15. "status":{
  16. "capacity":{"cpu":"8"},
  17. "addresses":[
  18. {"type": "LegacyHostIP", "address":"127.0.0.2"},
  19. {"type": "another", "address":"127.0.0.3"}
  20. ]
  21. }
  22. }
  23. ],
  24. "users":[
  25. {
  26. "name": "myself",
  27. "user": {}
  28. },
  29. {
  30. "name": "e2e",
  31. "user": {"username": "admin", "password": "secret"}
  32. }
  33. ]
  34. }
函数描述示例结果
text纯文本kind is {.kind}kind is List
@当前对象{@}与输入相同
. or []子运算符{.kind} or {['kind']}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
range, end迭代列表{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

使用 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='{range .items[*]}{.metadata.name}{"\t"}{.status.startTime}{"\n"}{end}'

在 Windows 上,您必须 double 引用任何包含空格的 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}"