Невозможно получить доступ к элементу JSON с (-) из вывода Junos - Ansible 2.8 - PullRequest
0 голосов
/ 30 октября 2019

Мне нужна помощь при попытке получить доступ к элементу JSON, который содержит (-) из вывода junos_command. Я не могу понять, как получить bgp-информацию.

Я использую модуль junos_command. Я столкнулся с той же проблемой, используя также модуль juniper_junos_command.

Я использую Ansible версии 2.8

Из Playbook:

    - name: Show BGP neighbor JSON output
      junos_command:  
        commands:
          - show bgp neighbor 174.68.232.1
        display: json  
      register: configs

    - name: Debug output
      debug:
        var: configs.stdout[0]

    - name: Debug output
      debug:
        var: configs.stdout[0]['bgp-information']['bgp-peer']

Отладочный вывод (частичный):

TASK [Debug output] ***************************************************************************************************************************************************************************************
ok: [NEP6HDRJ31] => 
  configs.stdout[0]:
    bgp-information:
    - attributes:
        xmlns: http://xml.juniper.net/junos/16.1R4/junos-routing
      bgp-peer:
      - active-holdtime:
        - data: '90'
        attributes:
          junos:style: detail
        bgp-bfd:
        - bfd-configuration-state:
          - data: disabled
          bfd-operational-state:
          - data: down
        bgp-option-information:
        - address-families:
          - data: inet-unicast inet-multicast inet-vpn-unicast inet-vpn-multicast inet-labeled-unicast inet6-labeled-unicast inet-mvpn
          attributes:
            xmlns: http://xml.juniper.net/junos/16.1R4/junos-routing
          authentication-configured:
          - data:
            - null
          bgp-options:
          - data: Preference LocalAddress AdvertiseInactive AuthKey LogUpDown AddressFamily Multipath Rib-group Refresh
          bgp-options-extended:
          - {}
          bgp-options2:
          - {}
          export-policy:
          - data: iBGP-POLICY
          holdtime:
          - data: '90'
          import-policy:
          - data: iBGP-IN
          local-address:
          - data: 174.68.232.31


TASK [Debug output] ***************************************************************************************************************************************************************************************
ok: [NEP6HDRJ31] => 
  configs.stdout[0]['bgp-information']['bgp-peer']: VARIABLE IS NOT DEFINED!

Ответы [ 2 ]

0 голосов
/ 11 ноября 2019

Я нашел решение с помощью regex_replace.

    - name: Show BGP neighbor JSON output
      juniper_junos_command:  
        provider: "{{ credentials }}"
        commands:
          - show bgp neighbor 174.68.232.1
        display: json  
      register: configs

    - name: set fact
      set_fact:
        bgp_neighbor: "{{ configs.parsed_output | regex_replace('-', '_') }}"

    - name: Debug output
      debug:
        var: bgp_neighbor.bgp_information[0].bgp_peer[0].peer_state[0].data

    - name: Debug output
      debug:
        var: bgp_neighbor.bgp_information[0].bgp_peer[0].description[0].data 

    - name: Debug output
      debug:
        var: bgp_neighbor.bgp_information[0].bgp_peer[0].peer_id[0].data     

    - name: BGP Status
      debug:
        msg: |
            "peer name: {{ bgp_neighbor.bgp_information[0].bgp_peer[0].description[0].data }}
             peer address: {{ bgp_neighbor.bgp_information[0].bgp_peer[0].peer_id[0].data }}
             peer state: {{ bgp_neighbor.bgp_information[0].bgp_peer[0].peer_state[0].data }}"
TASK [Debug output] *********************************************************************************************************************************************************************************************
ok: [NEP6HDRJ31] => 
  bgp_neighbor.bgp_information[0].bgp_peer[0].peer_state[0].data: Established
TASK [Debug output] *********************************************************************************************************************************************************************************************
ok: [NEP6HDRJ31] => 
  bgp_neighbor.bgp_information[0].bgp_peer[0].description[0].data: NEP6BPRJ01
TASK [Debug output] *********************************************************************************************************************************************************************************************
ok: [NEP6HDRJ31] => 
  bgp_neighbor.bgp_information[0].bgp_peer[0].peer_id[0].data: 174.68.232.1
TASK [BGP Status] ***********************************************************************************************************************************************************************************************
ok: [NEP6HDRJ31] => 
  msg: |-
    "peer name: NEP6BPRJ01
     peer address: 174.68.232.1
     peer state: Established"

PLAY RECAP ******************************************************************************************************************************************************************************************************
NEP6HDRJ31                 : ok=6    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0 

0 голосов
/ 30 октября 2019

Вы можете видеть, что bgp-information является переменной списка (следующая строка начинается с тире). поэтому ваше последнее задание должно быть:

- name: Debug output
  debug:
    var: configs.stdout[0]['bgp-information'][0]['bgp-peer']

надеюсь, что это поможет

ОБНОВЛЕНИЕ

Я взял предоставленный вами вывод и определил его в видеПеременная, вот книга воспроизведения, которая использовалась для проверки ответа:

---
- hosts: localhost
  gather_facts: false
  vars:
    configs_stdout:
    - bgp-information:
      - attributes:
          xmlns: http://xml.juniper.net/junos/16.1R4/junos-routing
        bgp-peer:
        - active-holdtime:
          - data: '90'
          attributes:
            junos:style: detail
          bgp-bfd:
          - bfd-configuration-state:
            - data: disabled
            bfd-operational-state:
            - data: down
          bgp-option-information:
          - address-families:
            - data: inet-unicast inet-multicast inet-vpn-unicast inet-vpn-multicast inet-labeled-unicast inet6-labeled-unicast inet-mvpn
            attributes:
              xmlns: http://xml.juniper.net/junos/16.1R4/junos-routing
            authentication-configured:
            - data:
              - null
            bgp-options:
            - data: Preference LocalAddress AdvertiseInactive AuthKey LogUpDown AddressFamily Multipath Rib-group Refresh
            bgp-options-extended:
            - {}
            bgp-options2:
            - {}
            export-policy:
            - data: iBGP-POLICY
            holdtime:
            - data: '90'
            import-policy:
            - data: iBGP-IN
            local-address:
            - data: 174.68.232.31

  tasks:
  - name: Debug output
    debug:
      var: configs_stdout

  - name: Debug output
    debug:
      var: configs_stdout[0]['bgp-information'][0]['bgp-peer']

если вы запустите PB, вы убедитесь, что var: configs.stdout[0]['bgp-information'][0]['bgp-peer'] работает.

...