亚马逊云科技 - 使用 aws-cli 1.3.6 列出实例名称以及其他数据



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

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,我们可以看到 Tags 选择返回一个列表(单元素列表),这可能是问题所在:

[
    [
        [
            "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]'

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

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

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

提前感谢!

因此,问题是:有没有办法选择过滤器结果的第一个元素(?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  |
+--------------------+-----------+
#!/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"

它告诉实例 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

最新更新