如何解析json以从
的输出中检索字段kubectl get pods -o json
从命令行我需要从谷歌云集群中获取系统生成的容器名称...以下是来自上述命令的json输出的显着位:
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
我想避免文本解析输出
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
答案 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