28

使用 aws-cli 1.3.6 我正在尝试获取我的 ec2 实例的简单表,其中包含名称和状态。我一直在查看 --query 和 JMESpath 文档,并且能够选择 Map 的“值”项,其中“键”项等于名称。这对于获取实例名称很有用。因此,下面的代码似乎工作

aws ec2 describe-instances --output table --query 'Reservations[].Instances[].Tags[?Key==`Name`].Value'

并提供这个:

-------------------
|DescribeInstances|
+-----------------+
|  Name1          |
|  Name2          |
+-----------------+

但是,如果我想添加状态,事情就不会像我预期的那样。使用

aws ec2 describe-instances --output table --query 'Reservations[].Instances[].[Tags[?Key==`Name`].Value,State.Name]'

提供

-------------------
|DescribeInstances|
+-----------------+
|  Name1          |
|  stopped        |
|  Name2          |
|  stopped        |
+-----------------+

而不是带有名称和状态的两列表。

如果我们将输出转换为 JSON,我们可以看到标签选择返回一个列表(单元素列表),这可能是问题所在:

[
    [
        [
            "Name1"
        ],
        "stopped"
    ],
    [
        [
            "Name2"
        ],
        "stopped"
    ]
]

我无法通过选择第一个元素将此列表转换为标量。这,行不通。返回一个空列表作为名称。

aws ec2 describe-instances --output json --query 'Reservations[].Instances[].[Tags[?Key==`Name`].Value[0],State.Name]'

和这个一样

aws ec2 describe-instances --output json --query 'Reservations[].Instances[].[Tags[?Key==`Name`].Value[][0],State.Name]'

我想出解决这个问题的唯一方法是通过 join 函数。因为我只期望一个元素,所以没关系,但我似乎有点 hacky。

aws ec2 describe-instances --output table --query 'Reservations[].Instances[].[join(`,`,Tags[?Key==`Name`].Value),State.Name]'

---------------------------
|    DescribeInstances    |
+-------------+-----------+
|  Name1      |  stopped  |
|  Name2      |  stopped  |
+-------------+-----------+

因此,问题是:有没有什么方法可以选择过滤器结果的第一个元素,(?Key==XXXX)记住后缀[0]似乎不起作用?

提前致谢!

4

3 回答 3

28

因此,问题是:是否有任何方法可以选择过滤器结果的第一个元素 (?Key==XXXX) 记住用 [0] 后缀似乎不起作用?

您对这个问题的表述方式实际上暗示了解决方案,即管道表达式(但仅在aws-cli的 1.3.7 版本中可用,因此在提问时无法弄清楚):

pipe-expression  = expression "|" expression

管道表达式组合了两个表达式,用 | 分隔 特点。它类似于具有两个重要区别的子表达式:

  1. 任何表达式都可以用在右手边。子表达式限制可以在右侧使用的表达式类型。
  2. 管道表达式停止左侧的投影以传播到右侧。如果左侧表达式创建投影,则不适用于右侧。

强调的部分是关键,如后续示例所示,特别是:

如果您只想要第一个子列表 ["first1", "second1"],则可以使用管道表达式:

foo[*].bar[0] -> ["first1", "first2"]
foo[*].bar | [0] -> ["first1", "second1"]

解决方案

因此,应用管道表达式会产生所需的结果:

aws ec2 describe-instances --output table \
  --query 'Reservations[].Instances[].[Tags[?Key==`Name`] | [0].Value, State.Name]'

----------------------------------
|        DescribeInstances       |
+--------------------+-----------+
|  Name1             |  stopped  |
|  Name2             |  stopped  |
+--------------------+-----------+
于 2014-05-03T13:29:23.177 回答
1

它告诉实例 ID 以及服务器状态

Command:
aws ec2 describe-instances --filter Name=tag:Name,Values=eep --query 'Reservations[*].Instances[*].{id:State,ID:InstanceId}' --output table

Query part in the above command
It changes as per the requirement
--query 'Reservations[*].Instances[*].{id:State,ID:InstanceId}' --output table
于 2018-01-01T12:09:27.673 回答
1
#!/bin/bash
for r in `aws ec2 describe-regions --query Regions[*].RegionName --output text`
do

    #echo $r
    aws ec2 describe-instances --region $r --query 'Reservations[*].Instances[*].{ID:InstanceId, type:InstanceType, launched:LaunchTime, name:Tags[?Key==`Name`].Value[]}' --output json | jq --arg R $r -r '.[] | .[] | [$R, .ID, .type, .launched, .name[0]] | @csv'

done

输出:

"us-east-1","i-054f8253b9ed0746d","t2.micro","2018-10-31T01:57:52.000Z","xxx"
"us-east-1","i-0638792b8b3057ce2","t2.nano","2018-10-23T03:49:24.000Z","yyy"
于 2018-11-29T09:13:38.290 回答