Ansible 是新出现的自动化运维工具,基于 Python 开发,集合了众多运维工具(puppet、cfengine、chef、func、fabric)的优点,实现了批量系统配置、批量程序部署、批量运行命令等等功能。
举个例子:
# 查看CPU 占用率的统计信息
display cpu-usage
# 查看内存的使用状态
display memory-usage
# 查看电源的工作状态
display power
# 查看接口是否工作在正常状态
display error-down recovery
# 查看VRRP的工作状态
display vrrp brief
# 查看NTP的工作状态
display ntp status
# 查看用户上线失败记录信息
display aaa online-fail-record
# 查看设备中的历史告警信息
display alarm history
以上是我们查看设备关键信息的常用命令,查看一台,可能还好,如果是100台,1000台呢?那我们是不是要重复执行100次、1000次?那可能我们这几天啥也不用干了!
Ansible就是一款自动化工具,通过一个命令完成一系列的操作,进而能减少重复性的工作和维护成本!
为了网工更高效工作,因此,就有了Ansible,一款自动化运维工具,通过一个命令完成一系列的操作,进而能减少重复性的工作和维护成本!
下面给大家简单说说Ansible的优点:
(1).轻量级,无需在客户端安装agent,更新时,只需在操作机上进行一次更新即可;
(2).批量任务执行可以写成脚本,而且不用分发到远程就可以执行;
(3).使用python编写,维护更简单,ruby语法过于复杂;
(4).支持sudo。
Ansible一般通过ssh协议实现linux服务器的管理,但从2.1版本开始,ansible core modules加入了对cisco ios设备的支持,对应的模块为ios_command, ios_config, ios_template。以下拓扑图是用于ansible测试的。
其中右上角的LinuxCacti里面是通过桥接至EVE-NG,此服务器里集成了cacti、ansible等工具。
一、 思科设备要设定ssh登录
aaa new-model
username admin privilege 15 password 7 142713
ip domain name vmise.com
crypto key generate rsa modulus 1024
line vty 0 4
transport input telnet ssh
二、ansible book
1.建立switchhost文件,switchhost文件内容格式如下:
备注:router表示设备分组,此可以自行定义,这个名字要跟后面的配置文档的名称一至。如下图就表示两个分组
2.建立三种类型的配置方案,文件结构如下:
3. 配置设定以router_acl这个为案例说明,router_acl目录结构如下:
4. router_acl中的tasks(即是需要执行的任务),配置如下:
[root@host05 tasks]# cat main.yml
---
- name: description cli
set_fact:
cli:
host: "`ansible_host`"
username: "`username`" --->从vars中配置的传过来参数
password: "`password`" --->从vars中配置的传过来参数
transport: cli
- name: configure acl
ios_template:
src: config.j2 ---->templates里的配置文件,即是路由器的配置脚本
provider: "`cli`"
- name: save running-config
ios_command:
commands: write memory ----> 配置保存命令
provider: "`cli`"
register: write_output
5. router_acl的vars配置文档
[root@host05 vars]# cat main.yml
username: admin ----->定义用户名
password: Password.123 ----->定义用户密码
router_interface: --->定义路由器接口组名称,后面执行作任务是要调用
- Ethernet1/0
- Ethernet1/1
- Ethernet1/2
6.router_acl中的templates 部分配置config.j2,即是路由器配置脚本
[root@host05 templates]# cat config.j2
ip access-list extended ingress-filter
remark Unassigned IANA address
1 deny ip 1.0.0.0 0.255.255.255 any
2 deny ip 2.0.0.0 0.255.255.255 any
3 deny ip 5.0.0.0 0.255.255.255 any
4 deny ip 7.0.0.0 0.255.255.255 any
5 deny ip 23.0.0.0 0.255.255.255 any
6 deny ip 27.0.0.0 0.255.255.255 any
7 deny ip 31.0.0.0 0.255
{% for interface in router_interface %} --->router_interface调用vars里的参数
interface `interface`
ip access-group ingress-filter in
{% endfor %}
7.router_acl.yml的配置如下:
[root@host05 ansible]# cat router_acl.yml
---
- hosts: router --->设备组,就是switchhost配置组
gather_facts: no
connection: local
roles:
- router_acl
8. 执行脚本命令 ansible-playbook -i switchhost router_acl.yml ,如成功如下图所示
上一条:Ansys Zemax如何使用 ZPL 创建用户自定义求解
下一条:Ansible 是如何发挥作用的?