如何使用jsonpath

时间:2016-03-24 23:20:42

标签: json parsing google-cloud-platform kubernetes

如何解析json以从

的输出中检索字段
kubectl get pods -o json

从命令行我需要从谷歌云集群中获取系统生成的容器名称...以下是来自上述命令的json输出的显着位: enter image description here

click here to see entire json output

所以最顶层的json键是一个数组:items []后跟metadata.labels.name,其中该复合键的搜索critera值是“web”(参见上图绿色标记)。在比赛中,我需要检索字段

.items[].metadata.name  

碰巧有价值:

web-controller-5e6ij   // I need to retrieve this value

Here are docs on jsonpath

我想避免文本解析输出

kubectl get pods

NAME                     READY     STATUS    RESTARTS   AGE
mongo-controller-h714w   1/1       Running   0          12m
web-controller-5e6ij     1/1       Running   0          9m

以下将正确解析此get pods命令,但我觉得它太脆弱了

kubectl get pods | tail -1 | cut -d' ' -f1

4 个答案:

答案 0 :(得分:8)

经过多次争斗后,这个衬里会检索容器名称:

kubectl get pods -o=jsonpath='{.items[?(@.metadata.labels.name=="web")].metadata.name}'

这是已知的搜索条件:

items[].metadata.labels.name  == "web"

这是要检索的理想字段

items[].metadata.name  :  "web-controller-5e6ij"

答案 1 :(得分:1)

如果要按标签过滤。您可以只使用kubectl -l标志。以下将执行相同的操作:

  

kubectl获取容器-l name = web -o = jsonpath ='{。items..metadata.name}'

答案 2 :(得分:1)

除了 Scott Stensland 的回答之外,还有一种格式化结果的方法:

kubectl get pods -o=jsonpath='{range .items[?(@.metadata.labels.name=="web")]}{.metadata.name}{"/n"}'

这会添加换行符。您也可以执行 {", "} 输出带空格的逗号。

另一种解决方案:

使用 JQ 得到格式良好的 json 结果:

kubectl get pods -o json | jq -r '.items[] | [filter] | [formatted result]' | jq -s '.'

[过滤器]示例:

select(.metadata.labels.name=="web")

[格式化结果]示例(如果需要,您可以添加更多字段):

{name: .metadata.name}

jq -s '.',用于将结果对象放入数组。

总结一下:

kubectl get pods -o json | jq -r '.items[] | select(.metadata.labels.name=="web") | {name: .metadata.name}' | jq -s '.'

然后就可以使用这个json数据得到想要的输出结果了。

答案 3 :(得分:0)

使用jq

有一种超级简单的方法

只需使用您已给定的参数传递输出,因为搜索到的值是second,请将索引放在方括号中。没有给出索引,意味着列出所有合适的对象。

<output> | jq .items[1].metadata.name 

您给出的示例(我将-r用作原始输出,不带引号)

curl -s https://gist.githubusercontent.com/scottstensland/278ce94dc6873aa54e44/raw/b2fc423bc4063a7cd16825f612e19d9a7faf5699/output%2520of%2520kubectl%2520get%2520pods%2520%2520-o%2520json| jq .items[1].metadata.name -r
web-controller-5e6ij