Ansible – Basic Playbook

LAB:  create a basic playbook just to ping 8.8.8.8

Host file contents under /etc/ansible/hosts. I have my NX-OS devices already included and configured the username for all devices (‘admin’)

[LAB_NXOS]
SPINE-1 ansible_host=192.168.255.1
SPINE-2 ansible_host=192.168.255.2
LEAF-1 ansible_host=192.168.255.3
LEAF-2 ansible_host=192.168.255.4

[LAB_NXOS:vars]
ansible_user=admin

Playbooks use YAML (YAML Ain’t Markup Language) which takes some getting used to. Below is the contents of my ‘playbook.yml’ file.
– ‘hosts’ maps to the ‘[LAB_NXOS]’ group within my /etc/ansible/hosts file.
– ‘connection: local’ (from what i understand) tells Ansible not to send a python script to the remote host for remote execution which NX-OS doesn’t support.
– ‘gather_facts: false’ isn’t supported by the Ansible module for NXOS. There are other modules which I will use later that can grab facts (serial number, hostname, configuration, etc)
– ‘nxos_command’ just tells Ansible to use the module specific for nxos. IOS uses ‘ios_command’.
– ‘commands’ is what you are actually running on the box

 

“playbook.yml”

 - name: Pinging from NXOS
   hosts: LAB_NXOS
   connection: local
   gather_facts: false
   tasks:
           - name: Pinging from NXOS
             nxos_command:
                     commands: "ping 8.8.8.8"

Now to run the playbook.

# First check to make sure the syntax is good to go. In this case there were no errors
BOX$ ansible-playbook playbook.yml --syntax-check

playbook: playbook.yml

# Running with --ask-pass because I do not have the password stored
BOX$ ansible-playbook playbook.yml --ask-pass
SSH password:

PLAY [Pinging from NXOS] **************************************************************************************************************

TASK [Pinging from NXOS] **************************************************************************************************************
ok: [SPINE-2]
ok: [SPINE-1]
ok: [LEAF-1]
ok: [LEAF-2]

PLAY RECAP ****************************************************************************************************************************
LEAF-1                     : ok=1    changed=0    unreachable=0    failed=0
LEAF-2                     : ok=1    changed=0    unreachable=0    failed=0
SPINE-1                    : ok=1    changed=0    unreachable=0    failed=0
SPINE-2                    : ok=1    changed=0    unreachable=0    failed=0

Just to see what a failure looks like, I configured a static route on LEAF-2 for 8.8.8.8 pointing to null0 and ran it again

BOX$ ansible-playbook playbook.yml --ask-pass
SSH password:

PLAY [Pinging from NXOS] **************************************************************************************************************************************

TASK [Pinging from NXOS] **************************************************************************************************************************************
ok: [SPINE-2]
ok: [SPINE-1]
ok: [LEAF-1]
fatal: [LEAF-2]: FAILED! => {"changed": false, "failed": true, "msg": "timeout trying to send command: ping 8.8.8.8"}
        to retry, use: --limit @/home/jason/ANS-TESTING-1/1.BASIC_PLAYBOOK/playbook.retry

PLAY RECAP ****************************************************************************************************************************************************
LEAF-1                     : ok=1    changed=0    unreachable=0    failed=0
LEAF-2                     : ok=0    changed=0    unreachable=0    failed=1
SPINE-1                    : ok=1    changed=0    unreachable=0    failed=0
SPINE-2                    : ok=1    changed=0    unreachable=0    failed=0

Ansible Playbook Documenation: http://docs.ansible.com/ansible/latest/playbooks.html

Network Architect | CCIEx3 #29824 JNCIE #2197 VCIX-NV

Leave a Comment