JSON-запрос для поиска новейшего снимка для хоста и устройства? - PullRequest
0 голосов
/ 21 сентября 2018

Я пытаюсь найти новейший снимок для устройства и хоста в AWS с помощью команды aws ec2.Я получаю следующий вывод от aws ec2 describe-snapshots.

. Как вы можете видеть, у меня может быть несколько снимков для одного хоста (см. Теги с ключами hostname и devicename) и устройства.Время начала отличается.

{
"Snapshots": [
    {
        "Description": "My desc.",
        "Encrypted": false,
        "VolumeId": "vol-aaa",
        "State": "completed",
        "VolumeSize": 8,
        "StartTime": "2018-02-02T19:27:56.000Z",
        "Progress": "100%",
        "OwnerId": "5674567",
        "SnapshotId": "snap-xxx"
    },  
    {
        "Description": "host1.domain.com - sdc",
        "Tags": [
            {
                "Value": "SNAP1",
                "Key": "Name"
            },
            {
                "Value": "sdc",
                "Key": "devicename"
            },
            {
                "Value": "host1.domain.com",
                "Key": "hostname"
            }
        ],
        "Encrypted": false,
        "VolumeId": "vol-xxx",
        "State": "completed",
        "VolumeSize": 140,
        "StartTime": "2018-09-21T08:39:58.000Z",
        "Progress": "100%",
        "OwnerId": "345634563456",
        "SnapshotId": "snap-xxx"
    },  
    {
        "Description": "host1.domain.com - sdc",
        "Tags": [
            {
                "Value": "SNAP2",
                "Key": "Name"
            },
            {
                "Value": "sdc",
                "Key": "devicename"
            },
            {
                "Value": "host1.domain.com",
                "Key": "hostname"
            }
        ],
        "Encrypted": false,
        "VolumeId": "vol-xxx",
        "State": "completed",
        "VolumeSize": 140,
        "StartTime": "2018-09-22T08:39:58.000Z",
        "Progress": "100%",
        "OwnerId": "345634563456",
        "SnapshotId": "snap-xxx"
    }

}

Как запросить этот JSON в Ansible, чтобы получить новейший снимок для имени хоста и устройства?Я делаю это не часто, поэтому бьюсь с синтаксисом запроса.

До сих пор у меня есть следующее.

 - shell: "aws ec2 describe-snapshots"
   register: snap
   delegate_to: localhost

 - debug:
     msg: "{{ snap.stdout | from_json | json_query(query) }}"
   vars:
     query: "Snapshots[].Tags[?Key=='hostname'].Value"

Но как мне выбрать все элементы снимка, где Tags.Value равнок определенному значению, где ключ является "имя хоста"?И как мне выбрать самый новый из списка, который я получаю?

1 Ответ

0 голосов
/ 22 сентября 2018

Согласно подробному руководству , JMESPath поддерживает вложенные выражения спецификатора скобок:

  vars:
    snap: |
      {
        "Snapshots": [
          {"Id": "aaa", "Tags": [{"Key": "hostname", "Value": "alpha"}]},
          {"Id": "bbb", "Tags": [{"Key": "hostname", "Value": "beta"}]}
        ]
      }
    jq: "Snapshots[? Tags[? Key=='hostname' && Value=='alpha']].Id"
  tasks:
  - debug:
      msg: "{{ snap | from_json | json_query(jq) }}"

Что касается части "для определенного хоста", то vars: query: подчиняется jinja2интерполяция, как и любая другая строка, например:

vars:
  query: ... [? Value=='{{ the_hostname }}' ] ...

Только будьте осторожны, чтобы убедиться, что значение правильно экранировано - что, вероятно, не будет проблемой для имени хоста, но я имею в виду вgeneral .

Затем, что касается «самой новой из списка», ISO8601 имеет очень приятное побочное преимущество лексографической сортировки, поэтому:

  vars:
    jq: "Snapshots[? Tags[? Key=='hostname' && Value=='alpha']]"
  tasks:
  - debug:
      msg: "{{ snap | from_json | json_query(jq) | sort(attribute='StartTime', reverse=True) }}"
...