AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / server / Perguntas / 1161973
Accepted
Matt Wagner
Matt Wagner
Asked: 2024-07-04 04:09:13 +0800 CST2024-07-04 04:09:13 +0800 CST 2024-07-04 04:09:13 +0800 CST

Ansible: Como mesclar uma lista e ditar em um novo ditado aninhado

  • 772

Estou tentando criar registros de pesquisa reversa (PTR) para ligação.

Eu tenho um arquivo CSV com campos IP e Hostname carregados em um dict (de read_csv), então acho que é uma lista de dictos:

ok: [localhost] => {
    "msg": [
        {
            "changed": false,
            "dict": {},
            "failed": false,
            "list": [
                {
                    "hostname": "host1",
                    "ip": "10.32.1.32"                                                            
                },
                {
                    "hostname": "host2",
                    "ip": "10.50.6.71"                                                            
                },
                {                                                                                     
                    "hostname": "host3",
                    "ip": "10.36.254.41"                                                          
                },
                {
                    "hostname": "host4",
                    "ip": "10.36.254.42"
                }
            ]
        },
    ]
}

E eu tenho uma lista de dois últimos octetos invertidos exclusivos derivados do ditado acima:

ok: [localhost] => {
    "msg": [
        [
            "32.10",
            "50.10",
            "36.10"
        ],
    ]
}

O que eu quero é um novo ditado parecido (a formatação pode não estar correta, por favor, perdoe):

{
   "32.10": 
          {
              "hostname": "host1",
              "ip": "10.32.1.32"                                                            
          },
   "50.10":
          {
              "hostname": "host2",
              "ip": "10.50.6.71"                                                            
          },
   "36.10":
          {                                                                                     
              "hostname": "host3",
              "ip": "10.36.254.41"                                                          
          },
          {
              "hostname": "host4",
              "ip": "10.36.254.42"
          }
}

O novo ditado "super" deve ter apenas as entradas IP + Nome do host para aquela rede correspondente (por exemplo, todas as entradas 10.36.xx devem estar em "36.10").

A partir desse novo ditado, eu deveria ser capaz de percorrê-lo em um modelo para gerar os registros PTR.

Estou perplexo sobre como mesclar essas duas estruturas de dados. :-/

Obrigado!

ansible
  • 1 1 respostas
  • 12 Views

1 respostas

  • Voted
  1. Best Answer
    larsks
    2024-07-04T04:57:47+08:002024-07-04T04:57:47+08:00

    Você pode usar o combinefiltro para construir seu dicionário final.

    Algo assim:

    - hosts: localhost
      gather_facts: false
      vars:
        results:
          - hostname: host1
            ip: 10.32.1.32
          - hostname: host2
            ip: 10.50.6.71
          - hostname: host3
            ip: 10.36.254.41
          - hostname: host4
            ip: 10.36.254.42
      tasks:
        - loop: "{{ results }}"
          vars:
            reversed: {}
            key: >-
              {{"{}.{}".format(*((item.ip.split('.'))[:2]|reverse))}}
          set_fact:
            reversed: >-
              {{
              reversed|combine({key: reversed.get(key, []) + [item]}, list_merge='append_rp')
              }}
    
        - debug:
            var: "reversed"
    

    Construímos a chave do dicionário usando a seguinte expressão:

    {{"{}.{}".format(*((item.ip.split('.'))[:2]|reverse))}}
    

    Isso transforma algo como "abcd" em "ba". Usamos isso + o combinefiltro + a list_mergeopção do combinefiltro para obter a estrutura de dados final; o manual acima produz esta saída:

    TASK [debug] *******************************************************************
    ok: [localhost] => {
        "reversed": {
            "32.10": [
                {
                    "hostname": "host1",
                    "ip": "10.32.1.32"
                }
            ],
            "36.10": [
                {
                    "hostname": "host3",
                    "ip": "10.36.254.41"
                },
                {
                    "hostname": "host4",
                    "ip": "10.36.254.42"
                }
            ],
            "50.10": [
                {
                    "hostname": "host2",
                    "ip": "10.50.6.71"
                }
            ]
        }
    }
    
    • 0

relate perguntas

  • Ansible: Converter string em dicionário

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Você pode passar usuário/passar para autenticação básica HTTP em parâmetros de URL?

    • 5 respostas
  • Marko Smith

    Ping uma porta específica

    • 18 respostas
  • Marko Smith

    Verifique se a porta está aberta ou fechada em um servidor Linux?

    • 7 respostas
  • Marko Smith

    Como automatizar o login SSH com senha?

    • 10 respostas
  • Marko Smith

    Como posso dizer ao Git para Windows onde encontrar minha chave RSA privada?

    • 30 respostas
  • Marko Smith

    Qual é o nome de usuário/senha de superusuário padrão para postgres após uma nova instalação?

    • 5 respostas
  • Marko Smith

    Qual porta o SFTP usa?

    • 6 respostas
  • Marko Smith

    Linha de comando para listar usuários em um grupo do Windows Active Directory?

    • 9 respostas
  • Marko Smith

    O que é um arquivo Pem e como ele difere de outros formatos de arquivo de chave gerada pelo OpenSSL?

    • 3 respostas
  • Marko Smith

    Como determinar se uma variável bash está vazia?

    • 15 respostas
  • Martin Hope
    Davie Ping uma porta específica 2009-10-09 01:57:50 +0800 CST
  • Martin Hope
    kernel O scp pode copiar diretórios recursivamente? 2011-04-29 20:24:45 +0800 CST
  • Martin Hope
    Robert ssh retorna "Proprietário incorreto ou permissões em ~/.ssh/config" 2011-03-30 10:15:48 +0800 CST
  • Martin Hope
    Eonil Como automatizar o login SSH com senha? 2011-03-02 03:07:12 +0800 CST
  • Martin Hope
    gunwin Como lidar com um servidor comprometido? 2011-01-03 13:31:27 +0800 CST
  • Martin Hope
    Tom Feiner Como posso classificar a saída du -h por tamanho 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich O que é um arquivo Pem e como ele difere de outros formatos de arquivo de chave gerada pelo OpenSSL? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent Como determinar se uma variável bash está vazia? 2009-05-13 09:54:48 +0800 CST

Hot tag

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve