1.介绍
ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet、cfengine、chef、func、fabric)的优点,实现了批量系统配置、批量程序部署、批量运行命令等功能。ansible是基于模块工作的,本身没有批量部署的能力。真正具有批量部署的是ansible所运行的模块,ansible只是提供一种框架。主要包括:
(1) 连接插件connection plugins:负责和被监控端实现通信;
(2) host inventory:指定操作的主机,是一个配置文件里面定义监控的主机;
(3) 各种模块核心模块、command模块、自定义模块;
(3) 借助于插件完成记录日志邮件等功能;
(5) playbook:剧本执行多个任务时,非必需可以让节点一次性运行多个任务。
1.1 特性
(1) no agents:不需要在被管控主机上安装任何客户端;
(2) no server:无服务器端,使用时直接运行命令即可;
(3) modules in any languages:基于模块工作,可使用任意语言开发模块;
(3) yaml,not code:使用yaml语言定制剧本playbook;
(5) ssh by default:基于SSH工作;
(6) strong multi-tier solution:可实现多级指挥。
1.2 优点
(1) 轻量级,无需在客户端安装agent,更新时,只需在操作机上进行一次更新即可;
(2) 批量任务执行可以写成脚本,而且不用分发到远程就可以执行;
(3) 使用python编写,维护更简单,ruby语法过于复杂;
(3) 支持sudo
2.安装
2.1 准备三台机器 Centos7,测试时,建议关闭防火墙
master:192.168.1.130
slaver:192.168.1.11
slaver:192.168.1.23
2.2 编辑 hosts 文件(非必须)
两台都设置,若机器太多,可以通过搭建 DNS,则不用在每台机器上设置这个
192.168.1.130 master.test.com
192.168.1.11 slaver1.test.com
192.168.1.23 slaver2.test.com
2.3 设置 hostname(非必须)
在 master 上
vim /etc/sysconfig/network
HOSTNAME=master.test.com
<