Ansible фильтр карты из зарегистрированного выхода var - PullRequest
0 голосов
/ 14 февраля 2020

Я получаю с ansible через зарегистрированную переменную полную копию файла dhcpd.leases с одного сервера. Вывод с ansible debug выглядит следующим образом:

TASK [Show passive storage nodes info] *************************************************************************************************************************************************************
ok: [10.241.55.2] => {
    "msg": [
        "# The format of this file is documented in the dhcpd.leases(5) manual page.",
        "# This lease file was written by isc-dhcp-4.2.2",
        "",
        "lease 10.241.55.165 {",
        "  starts 4 2019/12/12 09:30:37;",
        "  ends 4 2019/12/12 21:30:37;",
        "  tstp 4 2019/12/12 21:30:37;",
        "  cltt 4 2019/12/12 09:30:37;",
        "  binding state free;",
        "  hardware ethernet b4:d1:35:00:04:50;",
        "  uid \"\\001\\264\\3215\\000\\004P\";",
        "}",
        "lease 10.241.55.163 {",
        "  starts 1 2019/12/16 08:10:56;",
        "  ends 1 2019/12/16 20:10:56;",
        "  tstp 1 2019/12/16 20:10:56;",
        "  cltt 1 2019/12/16 08:10:56;",
        "  binding state free;",
        "  hardware ethernet b4:d1:35:00:03:d7;",
        "}",
        "lease 10.241.55.159 {",
        "  starts 1 2019/12/16 08:52:20;",
        "  ends 1 2019/12/16 20:52:20;",
        "  tstp 1 2019/12/16 20:52:20;",
        "  cltt 1 2019/12/16 08:52:20;",
        "  binding state free;",
        "  hardware ethernet b4:d1:35:00:03:b4;",
        "}",
        "lease 10.241.55.166 {",
        "  starts 1 2019/12/16 08:54:38;",
        "  ends 1 2019/12/16 20:54:38;",
        "  tstp 1 2019/12/16 20:54:38;",
        "  cltt 1 2019/12/16 08:54:38;",
        "  binding state free;",
        "  hardware ethernet b4:d1:35:00:04:63;",
        "}",
        "lease 10.241.55.164 {",
        "  starts 1 2019/12/16 10:48:10;",
        "  ends 1 2019/12/16 22:48:10;",
        "  tstp 1 2019/12/16 22:48:10;",
        "  cltt 1 2019/12/16 10:48:10;",
        "  binding state free;",
        "  hardware ethernet b4:d1:35:00:04:4e;",
        "}",
        "lease 10.241.55.143 {",
        "  starts 5 2020/02/14 04:38:09;",
        "  ends 5 2020/02/14 16:38:09;",
        "  cltt 5 2020/02/14 04:38:09;",
        "  binding state active;",
        "  next binding state free;",
        "  rewind binding state free;",
        "  hardware ethernet 08:94:ef:9c:80:4a;",
        "  client-hostname \"linux-compute-e7d573cb9fda4e689939e21a7843c4fb\";",
        "}",
        "lease 10.241.55.148 {",
        "  starts 5 2020/02/14 05:03:08;",
        "  ends 5 2020/02/14 17:03:08;",
        "  cltt 5 2020/02/14 05:03:08;",
        "  binding state active;",
        "  next binding state free;",
        "  rewind binding state free;",
        "  hardware ethernet 00:e0:ec:ca:44:84;",
        "  client-hostname \"linux-storage-4391fc6548764de5a15a46b432d3cd37\";",
        "}",
        "lease 10.241.55.235 {",
        "  starts 5 2020/02/14 05:20:28;",
        "  ends 5 2020/02/14 17:20:28;",
        "  cltt 5 2020/02/14 05:20:28;",
        "  binding state active;",
        "  next binding state free;",
        "  rewind binding state free;",
        "  hardware ethernet 00:e0:ec:ca:45:74;",
        "  client-hostname \"linux-storage-58aba44ac09d4f639b9374b9142b1a53\";",
        "}",
        "lease 10.241.55.141 {",
        "  starts 5 2020/02/14 06:01:04;",
        "  ends 5 2020/02/14 18:01:04;",
        "  cltt 5 2020/02/14 06:01:04;",
        "  binding state active;",
        "  next binding state free;",
        "  rewind binding state free;",
        "  hardware ethernet 08:94:ef:9c:80:6c;",
        "  client-hostname \"linux-compute-d228bc79357c4c8b87c280f9efae6ba6\";",
        "}",
        "lease 10.241.55.236 {",
        "  starts 5 2020/02/14 06:12:28;",
        "  ends 5 2020/02/14 18:12:28;",
        "  cltt 5 2020/02/14 06:12:28;",
        "  binding state active;",
        "  next binding state free;",
        "  rewind binding state free;",
        "  hardware ethernet 00:e0:ec:ca:45:75;",
        "  client-hostname \"linux-storage-58aba44ac09d4f639b9374b9142b1a53\";",
        "}",
        "lease 10.241.55.140 {",
        "  starts 5 2020/02/14 06:13:18;",
        "  ends 5 2020/02/14 18:13:18;",
        "  cltt 5 2020/02/14 06:13:18;",
        "  binding state active;",
        "  next binding state free;",
        "  rewind binding state free;",
        "  hardware ethernet 08:94:ef:9c:80:24;",
        "  client-hostname \"linux-compute-d0a9a76a7b5249048f78642220a1958c\";",
        "}",

Есть ли в любом случае сопоставить поданный IP-адрес аренды + имя-клиента-клиента, основываясь на этом, чтобы выполнить фильтрацию и строго поместить ips в файл инвентаризации? Я знаю, что могу получить ips напрямую, но есть серверы, которые имеют 4 ips, поэтому они имеют одинаковое имя хоста. Вместо того, чтобы положить все 4 ips в инвентарь, мне нужен только один из ips (неважно, какой), и я пытаюсь сделать фильтрацию на основе имени хоста. Также в выводе есть записи, которые не имеют имени клиента-хоста, поэтому в идеале их следует игнорировать.

Вопрос похож на другой, который я выложил здесь: Ansible шаблон jina2, фильтр вывода основанный на уникальности

Но с этим я пытаюсь использовать другой подход.

То, что я до сих пор пробовал, это:

 debug:
   msg: "{{ p_storage_ips.stdout | map(attribute='client-hostname' | list) }}"

Но Я ничего не получаю: ЗАДАЧА [Показать информацию о пассивных узлах хранения]

ok: [10.241.55.2] => {
    "msg": "<generator object do_map at 0x7f40e52785f0>"
}

Также пробовал так:

   - set_fact:
       dhcp_hosts: "{{ dhcp.stdout_lines | selectattr('client-hostname', 'defined') | map(attribute='lease') | list }}"

Любая помощь будет очень признательна!

1 Ответ

0 голосов
/ 14 февраля 2020

Не берите в голову, я понял, что было бы намного проще отфильтровать вывод, отправленный на ansible непосредственно из bash. В конце концов я придумал следующее:

 awk '!seen[$0]++' /var/lib/dhcp/dhcpd.leases | grep -vE -- 'ends|starts|tstp|cltt|uid|bind|hardware' | grep -B1 storage | awk '{print $2}' | grep '^[0-9]'

Что дает 2 IP-адреса для узлов хранения (из 8).

10.241.55.148
10.241.55.235

Это не решает начальную вопрос, но, по крайней мере, дает желаемый ответ.

...