运行 aws ec2 describe-instances 将返回类似以下内容的 json 文本:
{
"Reservations": [
{
"Instances": [
"PublicDnsName": "ec2..."
"VpcId": "vpc-...",
...
"Instances": [
我知道对于每个“实例”,我可以使用 jq 提取单个字段的内容,例如 PublicDnsName,如下所示:
jq '.Reservations[].Instances[].PublicDnsName'
这将列出我的实例的 DNS 名称,但如何提取两个或多个字段并用空格或逗号等分隔它们?我希望每个实例的 PublicDnsName 和 VpcId 并排列出。
具体来说,我正在寻找的是 VpcId 为空、未定义或不存在的实例列表。换句话说,我想要一份我的 Classic 实例列表,我需要通过 API 获得它,以便处理结果。
答案1
以下是使用一些示例代码和数据的方法我对类似问题的回答在 Stack Overflow 上。
要选择多个字段,您可以使用对象构造。例如,此过滤器会创建一个仅包含PublicDnsName
每个VpcId
实例的对象:
.Reservations[]
| .Instances[]
| {PublicDnsName, VpcId}
如果此过滤器在filter.jq
并且来自其他答案的样本数据在,data.json
则运行
$ jq -M -f filter.jq data.json
生产
{
"PublicDnsName": "xxxxxxxx",
"VpcId": "vpc-eb09eb8e"
}
一旦你有了包含所需内容的对象,将数据转换为另一种格式(例如 csv)就很容易了。使用此过滤器
.Reservations[]
| .Instances[]
| {PublicDnsName, VpcId}
| [.[]]
| @csv
以及-r
选项
$ jq -M -r -f filter.jq data.json
jq生产
"xxxxxxxx","vpc-eb09eb8e"
要添加过滤条件,例如 VpcId 不为空,请添加选择。
.Reservations[]
| .Instances[]
| {PublicDnsName, VpcId}
| select(.VpcId != null)
| [.[]]
| @csv