1.python
ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet、cfengine、chef、func、fabric)的优势,实现了批量系统配置、批量程序部署、批量运行命令等功能。ansible是基于模块工做的,自己没有批量部署的能力。真正具备批量部署的是ansible所运行的模块,ansible只是提供一种框架。主要包括:ruby
(1)、链接插件connection plugins:负责和被监控端实现通讯;服务器
(2)、host inventory:指定操做的主机,是一个配置文件里面定义监控的主机;架构
(3)、各类模块核心模块、command模块、自定义模块;框架
(4)、借助于插件完成记录日志邮件等功能;运维
(5)、playbook:剧本执行多个任务时,非必需能够让节点一次性运行多个任务。ssh
2. 整体架构: 工具
3、特性插件
(1)、no agents:不须要在被管控主机上安装任何客户端;日志
(2)、no server:无服务器端,使用时直接运行命令便可;
(3)、modules in any languages:基于模块工做,可以使用任意语言开发模块;
(4)、yaml,not code:使用yaml语言定制剧本playbook;
(5)、ssh by default:基于SSH工做;
(6)、strong multi-tier solution:可实现多级指挥。
4、优势
(1)、轻量级,无需在客户端安装agent,更新时,只需在操做机上进行一次更新便可;
(2)、批量任务执行能够写成脚本,并且不用分发到远程就能够执行;
(3)、使用python编写,维护更简单,ruby语法过于复杂;
(4)、支持sudo。
5、任务执行流程