Resource module to configure interfaces.
Version added: 1.0.0
- This module manages the interface attributes of Cisco IOS network devices.
Note
- Tested against Cisco IOSXE Version 17.3 on CML.
- This module works with connection
network_cli
. See https://docs.ansible.com/ansible/latest/network/user_guide/platform_ios.html - The module examples uses callback plugin (stdout_callback = yaml) to generate task output in yaml format.
# Using merged
# Before state:
# -------------
#
# Router#sh running-config | section interface
# interface Loopback888
# no ip address
# interface Loopback999
# no ip address
# interface GigabitEthernet1
# ip address dhcp
# negotiation auto
# interface GigabitEthernet2
# description Configured and Merged by Ansible Network
# ip address dhcp
# speed 1000
# no negotiation auto
# interface GigabitEthernet3
# no ip address
# speed 1000
# no negotiation auto
# interface GigabitEthernet4
# no ip address
# shutdown
# negotiation auto
- name: Merge provided configuration with device configuration
cisco.ios.ios_interfaces:
config:
- name: GigabitEthernet2
description: Configured and Merged by Ansible Network
enabled: true
- name: GigabitEthernet3
description: Configured and Merged by Ansible Network
mtu: 3800
enabled: false
speed: 100
duplex: full
state: merged
# Task Output
# -----------
#
# before:
# - enabled: true
# name: GigabitEthernet1
# - description: Configured and Merged by Ansible Network
# enabled: true
# name: GigabitEthernet2
# speed: '1000'
# - description: Configured and Merged by Ansible Network
# enabled: false
# mtu: 3800
# name: GigabitEthernet3
# speed: '1000'
# - enabled: false
# name: GigabitEthernet4
# - enabled: true
# name: Loopback888
# - enabled: true
# name: Loopback999
# commands:
# - interface GigabitEthernet3
# - description Configured and Merged by Ansible Network
# - speed 100
# - mtu 3800
# - duplex full
# - shutdown
# after:
# - enabled: true
# name: GigabitEthernet1
# - description: Configured and Merged by Ansible Network
# enabled: true
# name: GigabitEthernet2
# speed: '1000'
# - description: Configured and Merged by Ansible Network
# enabled: true
# mtu: 2800
# name: GigabitEthernet3
# speed: '1000'
# - enabled: false
# name: GigabitEthernet4
# - enabled: true
# name: Loopback888
# - enabled: true
# name: Loopback999
# After state:
# ------------
#
# Router#show running-config | section ^interface
# interface Loopback888
# no ip address
# interface Loopback999
# no ip address
# interface GigabitEthernet1
# ip address dhcp
# negotiation auto
# interface GigabitEthernet2
# description Configured and Merged by Ansible Network
# ip address dhcp
# speed 1000
# no negotiation auto
# interface GigabitEthernet3
# description Configured and Merged by Ansible Network
# mtu 3800
# no ip address
# shutdown
# speed 1000
# no negotiation auto
# interface GigabitEthernet4
# no ip address
# shutdown
# negotiation auto
# Using merged - with mode attribute
# Before state:
# -------------
#
# vios#show running-config | section ^interface
# interface GigabitEthernet1
# description Configured by Ansible
# interface GigabitEthernet2
# description This is test
# interface GigabitEthernet3
# description This is test
# no switchport
- name: Merge provided configuration with device configuration
cisco.ios.ios_interfaces:
config:
- name: GigabitEthernet2
description: Configured and Merged by Ansible Network
enabled: true
mode: layer2
- name: GigabitEthernet3
description: Configured and Merged by Ansible Network
mode: layer3
state: merged
# Task Output
# -----------
#
# before:
# - enabled: true
# name: GigabitEthernet1
# - description: Configured and Merged by Ansible Network
# name: GigabitEthernet2
# - description: Configured and Merged by Ansible Network
# name: GigabitEthernet3
# commands:
# - interface GigabitEthernet2
# - description Configured and Merged by Ansible Network
# - switchport
# - interface GigabitEthernet3
# - description Configured and Merged by Ansible Network
# after:
# - enabled: true
# name: GigabitEthernet1
# - description: Configured and Merged by Ansible Network
# enabled: true
# name: GigabitEthernet2
# - description: Configured and Merged by Ansible Network
# name: GigabitEthernet3
# mode: layer3
# After state:
# ------------
#
# vios#show running-config | section ^interface
# interface GigabitEthernet1
# description Configured by Ansible
# interface GigabitEthernet2
# description Configured and Merged by Ansible Network
# interface GigabitEthernet3
# description Configured and Merged by Ansible Network
# no switchport
# Using replaced
# Before state:
# -------------
#
# vios#show running-config | section ^interface
# interface Loopback888
# no ip address
# interface Loopback999
# no ip address
# interface GigabitEthernet1
# description Management interface do not change
# ip address dhcp
# negotiation auto
# interface GigabitEthernet2
# ip address dhcp
# speed 1000
# no negotiation auto
# interface GigabitEthernet3
# no ip address
# speed 1000
# no negotiation auto
# interface GigabitEthernet4
# no ip address
# shutdown
# negotiation auto
# interface Vlan50
# ip address dhcp hostname testHostname
- name: Replaces device configuration of listed interfaces with provided configuration
cisco.ios.ios_interfaces:
config:
- name: GigabitEthernet3
description: Configured and Replaced by Ansible Network
enabled: false
speed: 1000
state: replaced
# Task Output
# -----------
#
# before:
# - description: Management interface do not change
# enabled: true
# name: GigabitEthernet1
# - enabled: true
# name: GigabitEthernet2
# speed: '1000'
# - enabled: true
# name: GigabitEthernet3
# speed: '1000'
# - enabled: false
# name: GigabitEthernet4
# - enabled: true
# name: Loopback888
# - enabled: true
# name: Loopback999
# - enabled: true
# name: Vlan50
# commands:
# - interface GigabitEthernet3
# - description Configured and Replaced by Ansible Network
# - shutdown
# after:
# - description: Management interface do not change
# enabled: true
# name: GigabitEthernet1
# - enabled: true
# name: GigabitEthernet2
# speed: '1000'
# - description: Configured and Replaced by Ansible Network
# enabled: false
# name: GigabitEthernet3
# speed: '1000'
# - enabled: false
# name: GigabitEthernet4
# - enabled: true
# name: Loopback888
# - enabled: true
# name: Loopback999
# - enabled: true
# name: Vlan50
# After state:
# -------------
#
# vios#show running-config | section ^interface
# interface Loopback888
# no ip address
# interface Loopback999
# no ip address
# interface GigabitEthernet1
# description Management interface do not change
# ip address dhcp
# negotiation auto
# interface GigabitEthernet2
# ip address dhcp
# speed 1000
# no negotiation auto
# interface GigabitEthernet3
# description Configured and Replaced by Ansible Network
# no ip address
# shutdown
# speed 1000
# no negotiation auto
# interface GigabitEthernet4
# no ip address
# shutdown
# negotiation auto
# interface Vlan50
# ip address dhcp hostname testHostname
# Using overridden
# Before state:
# -------------
#
# vios#show running-config | section ^interface
# interface Loopback888
# no ip address
# interface Loopback999
# no ip address
# interface GigabitEthernet1
# description Management interface do not change
# ip address dhcp
# negotiation auto
# interface GigabitEthernet2
# ip address dhcp
# speed 1000
# no negotiation auto
# interface GigabitEthernet3
# description Configured and Replaced by Ansible Network
# no ip address
# shutdown
# speed 1000
# no negotiation auto
# interface GigabitEthernet4
# no ip address
# shutdown
# negotiation auto
# interface Vlan50
# ip address dhcp hostname testHostname
- name: Override device configuration of all interfaces with provided configuration
cisco.ios.ios_interfaces:
config:
- description: Management interface do not change
enabled: true
name: GigabitEthernet1
- name: GigabitEthernet2
description: Configured and Overridden by Ansible Network
speed: 10000
- name: GigabitEthernet3
description: Configured and Overridden by Ansible Network
enabled: false
state: overridden
# Task Output
# -----------
#
# before:
# - description: Management interface do not change
# enabled: true
# name: GigabitEthernet1
# - enabled: true
# name: GigabitEthernet2
# speed: '1000'
# - description: Configured and Replaced by Ansible Network
# enabled: false
# name: GigabitEthernet3
# speed: '1000'
# - enabled: false
# name: GigabitEthernet4
# - enabled: true
# name: Loopback888
# - enabled: true
# name: Loopback999
# - enabled: true
# name: Vlan50
# commands:
# - interface loopback888
# - shutdown
# - interface loopback999
# - shutdown
# - interface Vlan50
# - shutdown
# - interface GigabitEthernet2
# - description Configured and Overridden by Ansible Network
# - speed 10000
# - interface GigabitEthernet3
# - description Configured and Overridden by Ansible Network
# - no speed 1000
# after:
# - description: Management interface do not change
# enabled: true
# name: GigabitEthernet1
# - description: Configured and Overridden by Ansible Network
# enabled: true
# name: GigabitEthernet2
# speed: '10000'
# - description: Configured and Overridden by Ansible Network
# enabled: false
# name: GigabitEthernet3
# speed: '1000'
# - enabled: false
# name: GigabitEthernet4
# - enabled: false
# name: Loopback888
# - enabled: false
# name: Loopback999
# - enabled: false
# name: Vlan50
# After state:
# -------------
#
# vios#show running-config | section ^interface
# interface Loopback888
# no ip address
# shutdown
# interface Loopback999
# no ip address
# shutdown
# interface GigabitEthernet1
# description Management interface do not change
# ip address dhcp
# negotiation auto
# interface GigabitEthernet2
# description Configured and Overridden by Ansible Network
# ip address dhcp
# speed 10000
# no negotiation auto
# interface GigabitEthernet3
# description Configured and Overridden by Ansible Network
# no ip address
# shutdown
# speed 1000
# no negotiation auto
# interface GigabitEthernet4
# no ip address
# shutdown
# negotiation auto
# interface Vlan50
# ip address dhcp hostname testHostname
# shutdown
# Using Deleted
# Before state:
# -------------
#
# vios#show running-config | section ^interface
# interface Loopback888
# no ip address
# shutdown
# interface Loopback999
# no ip address
# shutdown
# interface GigabitEthernet1
# description Management interface do not change
# ip address dhcp
# negotiation auto
# interface GigabitEthernet2
# description Configured and Overridden by Ansible Network
# ip address dhcp
# speed 10000
# no negotiation auto
# interface GigabitEthernet3
# description Configured and Overridden by Ansible Network
# no ip address
# shutdown
# speed 1000
# no negotiation auto
# interface GigabitEthernet4
# no ip address
# shutdown
# negotiation auto
# interface Vlan50
# ip address dhcp hostname testHostname
# shutdown
- name: "Delete interface attributes (Note: This won't delete the interface itself)"
cisco.ios.ios_interfaces:
config:
- name: GigabitEthernet2
state: deleted
# Task Output
# -----------
#
# before:
# - description: Management interface do not change
# enabled: true
# name: GigabitEthernet1
# - description: Configured and Overridden by Ansible Network
# enabled: true
# name: GigabitEthernet2
# speed: '10000'
# - description: Configured and Overridden by Ansible Network
# enabled: false
# name: GigabitEthernet3
# speed: '1000'
# - enabled: false
# name: GigabitEthernet4
# - enabled: false
# name: Loopback888
# - enabled: false
# name: Loopback999
# - enabled: false
# name: Vlan50
# commands:
# - interface GigabitEthernet2
# - no description Configured and Overridden by Ansible Network
# - no speed 10000
# - shutdown
# after:
# - description: Management interface do not change
# enabled: true
# name: GigabitEthernet1
# - enabled: false
# name: GigabitEthernet2
# speed: '1000'
# - description: Configured and Overridden by Ansible Network
# enabled: false
# name: GigabitEthernet3
# speed: '1000'
# - enabled: false
# name: GigabitEthernet4
# - enabled: false
# name: Loopback888
# - enabled: false
# name: Loopback999
# - enabled: false
# name: Vlan50
# After state:
# -------------
#
# vios#show running-config | section ^interface
# interface Loopback888
# no ip address
# shutdown
# interface Loopback999
# no ip address
# shutdown
# interface GigabitEthernet1
# description Management interface do not change
# ip address dhcp
# negotiation auto
# interface GigabitEthernet2
# ip address dhcp
# shutdown
# speed 1000
# no negotiation auto
# interface GigabitEthernet3
# description Configured and Overridden by Ansible Network
# no ip address
# shutdown
# speed 1000
# no negotiation auto
# interface GigabitEthernet4
# no ip address
# shutdown
# negotiation auto
# interface Vlan50
# ip address dhcp hostname testHostname
# shutdown
# Using Purged
# Before state:
# -------------
#
# vios#show running-config | section ^interface
# interface Loopback888
# no ip address
# shutdown
# interface Loopback999
# no ip address
# shutdown
# interface GigabitEthernet1
# description Management interface do not change
# ip address dhcp
# negotiation auto
# interface GigabitEthernet2
# ip address dhcp
# shutdown
# speed 1000
# no negotiation auto
# interface GigabitEthernet3
# description Configured and Overridden by Ansible Network
# no ip address
# shutdown
# speed 1000
# no negotiation auto
# interface GigabitEthernet4
# no ip address
# shutdown
# negotiation auto
# interface Vlan50
# ip address dhcp hostname testHostname
# shutdown
- name: "Purge given interfaces (Note: This will delete the interface itself)"
cisco.ios.ios_interfaces:
config:
- name: Loopback888
- name: Vlan50
state: purged
# Task Output
# -----------
#
# before:
# - description: Management interface do not change
# enabled: true
# name: GigabitEthernet1
# - enabled: false
# name: GigabitEthernet2
# speed: '1000'
# - description: Configured and Overridden by Ansible Network
# enabled: false
# name: GigabitEthernet3
# speed: '1000'
# - enabled: false
# name: GigabitEthernet4
# - enabled: false
# name: Loopback888
# - enabled: false
# name: Loopback999
# - enabled: false
# name: Vlan50
# commands:
# - no interface loopback888
# - no interface Vlan50
# after:
# - description: Management interface do not change
# enabled: true
# name: GigabitEthernet1
# - enabled: false
# name: GigabitEthernet2
# speed: '1000'
# - description: Configured and Overridden by Ansible Network
# enabled: false
# name: GigabitEthernet3
# speed: '1000'
# - enabled: false
# name: GigabitEthernet4
# - enabled: false
# name: Loopback999
# After state:
# -------------
#
# vios#show running-config | section ^interface
# interface Loopback999
# no ip address
# shutdown
# interface GigabitEthernet1
# description Management interface do not change
# ip address dhcp
# negotiation auto
# interface GigabitEthernet2
# ip address dhcp
# shutdown
# speed 1000
# no negotiation auto
# interface GigabitEthernet3
# description Configured and Overridden by Ansible Network
# no ip address
# shutdown
# speed 1000
# no negotiation auto
# interface GigabitEthernet4
# no ip address
# shutdown
# negotiation auto
# Using gathered
# Before state:
# -------------
#
# vios#sh running-config | section ^interface
# interface Loopback999
# no ip address
# shutdown
# interface GigabitEthernet1
# description Management interface do not change
# ip address dhcp
# negotiation auto
# interface GigabitEthernet2
# ip address dhcp
# shutdown
# speed 1000
# no negotiation auto
# interface GigabitEthernet3
# description Configured and Overridden by Ansible Network
# no ip address
# shutdown
# speed 1000
# no negotiation auto
# interface GigabitEthernet4
# no ip address
# shutdown
# negotiation auto
- name: Gather facts of interfaces
cisco.ios.ios_interfaces:
config:
state: gathered
# Task Output
# -----------
#
# gathered:
# - description: Management interface do not change
# enabled: true
# name: GigabitEthernet1
# - enabled: false
# name: GigabitEthernet2
# speed: '1000'
# - description: Configured and Overridden by Ansible Network
# enabled: false
# name: GigabitEthernet3
# speed: '1000'
# - enabled: false
# name: GigabitEthernet4
# - enabled: false
# name: Loopback999
# Using rendered
- name: Render the commands for provided configuration
cisco.ios.ios_interfaces:
config:
- name: GigabitEthernet1
description: Configured by Ansible-Network
mtu: 110
enabled: true
duplex: half
- name: GigabitEthernet2
description: Configured by Ansible-Network
mtu: 2800
enabled: false
speed: 100
duplex: full
state: rendered
# Task Output
# -----------
#
# rendered:
# - interface GigabitEthernet1
# - description Configured by Ansible-Network
# - mtu 110
# - duplex half
# - no shutdown
# - interface GigabitEthernet2
# - description Configured by Ansible-Network
# - speed 100
# - mtu 2800
# - duplex full
# - shutdown
# Using parsed
# File: parsed.cfg
# ----------------
#
# interface Loopback999
# no ip address
# shutdown
# interface GigabitEthernet1
# description Management interface do not change
# ip address dhcp
# negotiation auto
# interface GigabitEthernet2
# ip address dhcp
# shutdown
# speed 1000
# no negotiation auto
# interface GigabitEthernet3
# description Configured and Overridden by Ansible Network
# no ip address
# shutdown
# speed 1000
# no negotiation auto
# interface GigabitEthernet4
# no ip address
# shutdown
# negotiation auto
- name: Parse the provided configuration
cisco.ios.ios_interfaces:
running_config: "{{ lookup('file', 'parsed.cfg') }}"
state: parsed
# Task Output
# -----------
#
# parsed:
# - description: Management interface do not change
# enabled: true
# name: GigabitEthernet1
# - enabled: false
# name: GigabitEthernet2
# speed: '1000'
# - description: Configured and Overridden by Ansible Network
# enabled: false
# name: GigabitEthernet3
# speed: '1000'
# - enabled: false
# name: GigabitEthernet4
# - enabled: false
# name: Loopback999
Common return values are documented here, the following are the fields unique to this module:
- Sumit Jaiswal (@justjais)
- Sagar Paul (@KB-perByte)