先决条件

- 了解ansible基本操作

- 了解网络设备相关操作

- 了解linux相关操作

安装

安装EPEL



yum install https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm



 

安装ansible



yum install ansible



 

确认ansible正确安装



ansible --version



 

 

交换机ansible管理模块 ansible控制交换机_运维

 

 测试ssh连接

在使用ansible之前,测试一下ssh连接网络设备,保证网络设备的ssh协议开启,账号密码正确。

交换机ansible管理模块 ansible控制交换机_运维_02

1是账号,2是网络设备的ip。

 

创建inventory

inventory文件用来存放设备的相关信息,如ip地址、用户名、密码等。

文件名字可以叫inventory,也可以叫任何其它的名字,不加后缀。

文件内容如下:

1. 创建一个switches组,包含两台交换机, 第一列是交换机名(名字随便起),第二列的ansible_host是设备ip地址;

2. vars下面配置了switches组通用的变量,ansible_connection是连接方式,之后是操作系统类型ios,最后是登录的用户名。



[switches]
cisco_2960_06 ansible_host=x.x.x.x
cisco_2960_07 ansible_host=x.x.x.x

[switches:vars]
ansible_connection=network_cli
ansible_network_os=ios
ansible_user=username



 

创建playbook

playbook的文件名后缀必须以.yml或.yaml结尾,我个人习惯前者。

内容如下:

name:playbook的名字,一般用于描述整个playbook的作用即可;

connection:连接方式,cisco ios必须用network_cli;

gather_facts:ansible会自动收集远端设备的信息,这个操作会消耗很长时间,一般没有特殊需求就设置为false关闭;

hosts:指定主机范围,这里是all,所有主机;

tasks:真正执行的任务都在这下面;

ios_config:这是一个ansible的模块,用来对cisco的ios设备进行配置的修改、备份。

backup:设置为yes,则会启用该模块的备份功能,会在运行playbook的当前目录下自动创建一个backup目录,配置会自动备份到该目录下。



---

- name: Network Getting Started First Playbook
  connection: network_cli
  gather_facts: false
  hosts: all
  tasks:

    - name: backup ios devices
      ios_config:
        backup: yes



 

运行playbook



ansible-playbook -i inventory -k -e ansible_network_os=ios first_playbook.yml



ansible-playbook 是可执行程序,用于执行playbook文件;

-i 调用inventory文件,这是之前配置的存放设备信息的文件;

-k 运行时提示输入密码。推荐使用这个参数,不要在inventory里存放设备密码,都是明文的,不安全;

-e 是extra的意思,额外参数。这里指定了设备操作系统版本ios(此处不是必须的,只是为了演示这个参数的用法);

最后一个参数是playbook文件的名字,此处是first_playbook.yml。

 

输出如下:

交换机ansible管理模块 ansible控制交换机_网络设备_03

 

 首先,由于指定了-k参数,系统会提示你输入SSH密码,这个密码是网络设备的登录密码。

最后显示ok,说明执行成功,没有报错。

 

查看当前目录,可以看到ansible自动创建了backup目录,并且该目录下有以日期时间为后缀的备份文件,说明备份成功。

交换机ansible管理模块 ansible控制交换机_运维_04