Ansible/Network-20180605-ansible for cisco-ios_command/ios_banner-unable to enter configuration mode

版权声明:欢迎转载,并请引用链接。 https://blog.csdn.net/u012251305/article/details/80579086

Problem

TASK [IOS | Set banner] *******************************************************************
fatal: [172.16.232.232]: FAILED! => {"changed": false, "err": "", "msg": "unable to enter configuration mode"}
TASK [IOS | Show configuration] *******************************************************************
fatal: [172.16.232.232]: FAILED! => {"changed": false, "msg": "show configuration\r\n              ^\r\n% Invalid input detected at '^' marker.\r\n\r\n********>", "rc": 1}
    to retry, use: --limit @/opt/cisco-ansible/set_facts.retry

Solution

两个问题一个对策,authorize和auth_pass加上之后才能进入特权模式。

  - name: SYS | Define provider
    set_fact:
      provider:
        host: "{{ inventory_hostname }}"
        username: "{{ mgmt_username }}"
        password: "{{ mgmt_password }}"
        auth_pass: "{{ mgmt_enable }}"
        authorize: yes

Reference

https://apimirror.com/ansible/network_debug_troubleshooting

More

附完整代码

# ios_banner
---
- hosts: ios_devices
  gather_facts: no
  connection: local

  vars_prompt:
  - name: "mgmt_username"
    prompt: "Username"
    private: no
  - name: "mgmt_password"
    prompt: "Password"
  - name: "mgmt_enable"
    prompt: "Enable"

  tasks:

  - name: SYS | Define provider
    set_fact:
      provider:
        host: "{{ inventory_hostname }}"
        username: "{{ mgmt_username }}"
        password: "{{ mgmt_password }}"
        auth_pass: "{{ mgmt_enable }}"
        authorize: yes

  - name: IOS | Set banner
    ios_banner:
      provider: "{{ provider }}"
      banner: login
      text: |
        this is my login banner
        that contains a multiline
        string
      state: present
# ios_command
---
- hosts: ios_devices
  gather_facts: no
  connection: local

  vars_prompt:
  - name: "mgmt_username"
    prompt: "Username"
    private: no
  - name: "mgmt_password"
    prompt: "Password"
  - name: "mgmt_enable"
    prompt: "Enable"

  tasks:
  - name: SYS | Define provider
    set_fact:
      provider:
        host: "{{ inventory_hostname }}"
        username: "{{ mgmt_username }}"
        password: "{{ mgmt_password }}"
        auth_pass: "{{ mgmt_enable }}"
        authorize: yes

  - name: IOS | Show configuration
    ios_command:
      provider: "{{ provider }}"
      commands:
        - show configuration
    register: configuration

  - debug: msg="{{ configuration.stdout_lines }}"

猜你喜欢

转载自blog.csdn.net/u012251305/article/details/80579086