Select 来自 JMESPATH 表达式的中级属性
Select mid-level attribute from JMESPATH expression
我正在尝试 select 使用 Ansible 的 json_query 特定虚拟机的集群名称,后者在后端使用 JMESPATH。
我已按照 http://jmespath.org 中的教程和示例进行操作,但无法构建正确的查询。
我的数据结构如下:
{
"datacenters": [
{
"name": "dc-a",
"clusters": [
{ "name": "cluster-a",
"hosts": [
{
"name": "host-a",
"vms": [
{
"name": "vm-a",
"summary": {
"mem": "8",
"diskGB": "78.00",
"annotation": "",
"state": "poweredOn",
"ostype": "Microsoft Windows Server 2008 R2 (64-bit)",
"cpu": "2"
}
},
{
"name": "vm-b",
"summary": {
"mem": "24",
"diskGB": "114.00",
"annotation": "",
"state": "poweredOn",
"ostype": "Microsoft Windows Server 2008 R2 (64-bit)",
"cpu": "4"
}
}]
}]
}]
}]
}
我可以使用下面的查询 select VM ('vm-a'),但我正在寻找集群 (即 'cluster-a').
datacenters[].clusters[].hosts[].vms[?name=='vm-a'].name[]
datacenters[].clusters[?contains(hosts[].vms[].name, 'vm-a')].name[]
我正在尝试 select 使用 Ansible 的 json_query 特定虚拟机的集群名称,后者在后端使用 JMESPATH。 我已按照 http://jmespath.org 中的教程和示例进行操作,但无法构建正确的查询。
我的数据结构如下:
{
"datacenters": [
{
"name": "dc-a",
"clusters": [
{ "name": "cluster-a",
"hosts": [
{
"name": "host-a",
"vms": [
{
"name": "vm-a",
"summary": {
"mem": "8",
"diskGB": "78.00",
"annotation": "",
"state": "poweredOn",
"ostype": "Microsoft Windows Server 2008 R2 (64-bit)",
"cpu": "2"
}
},
{
"name": "vm-b",
"summary": {
"mem": "24",
"diskGB": "114.00",
"annotation": "",
"state": "poweredOn",
"ostype": "Microsoft Windows Server 2008 R2 (64-bit)",
"cpu": "4"
}
}]
}]
}]
}]
}
我可以使用下面的查询 select VM ('vm-a'),但我正在寻找集群 (即 'cluster-a').
datacenters[].clusters[].hosts[].vms[?name=='vm-a'].name[]
datacenters[].clusters[?contains(hosts[].vms[].name, 'vm-a')].name[]