一.ansible介绍
经常使用的自动化运维工具 python
Puppet —基于 Ruby 开发,采用 C/S 架构,扩展性强,基于 SSL,远程命令执行相对较弱
SaltStack —基于 Python 开发,采用 C/S 架构,相对 puppet 更轻量级,配置语法使用 YMAL,使得配置 脚本更简单 Ansible —基于 Pythonparamiko 开发,分布式,无需客户端,轻量级,配置语法使用 YMAL 及 Jinja2 模板语言,更强的远程命令执行操做 其余 DevOps 请参看:https://github.com/geekwolf/sa-scripts/blob/master/devops.md
Ansible 是一个简单的自动化运维管理工具,能够用来自动化部署应用、配置、编排 task(持续 交付、无宕机更新等),采用 paramiko 协议库(fabric 也使用这个),经过 SSH 或者 ZeroMQ 等连 接主机,大概每 2 个月发布一个主版git
Ansible 工做机制 github
Ansible 在管理节点将 Ansible 模块经过 SSH 协议(或者 Kerberos、LDAP)推送到被管理端执 行,执行完以后自动删除,可使用 SVN 等来管理自定义模块及编排vim
由上面的图能够看到 Ansible 的组成由 5 个部分组成: 架构
Ansible:核心引擎运维
Modules:包括 Ansible 自带的核心模块(core modules)及自定义模块 (custom modules);分布式
核心模块:ansible模块资源分发到远程节点使其执行特定任务或匹配一个特定的状态。工具
自定义模块:若是核心模块不足以完成某种功能,能够添加自定义模块。oop
Plugins:完成模块功能的补充,包括链接插件、邮件插件等 测试
Playbooks:网上不少翻译为剧本,我的以为理解为编排更为合理;定义ansible任务的配置文件,能够将多个任务定义在一个剧本中,由ansible自动执行,剧本执行支持多个任务,能够由控制主机运行多个任务,同时对多台远程主机进行管理。
Inventory:定义 Ansible 管理主机的清单
ansible功能特性
二.安装ansible
安装前准备:
1.由于ansible是基于python的,因此先检查是否有python,若是没有须要安装(注意版本,版本太低,也可能致使安装失败)。
2.安装ansible前须要安装依赖包
yum -y install epel-release
......
ansible安装:
yum -y install ansible
.......
安装完成后须要配置机组:
vim /etc/ansible/hosts
这里个人机组名为[ccdoop],如下是个人另外2台机子的配置(本机为:test1:192.168.254.130)
test2 192.168.254.131
test3 192.168.254.132
到这里ansible就安装完成了。
测试:
ansible all -m ping
结果:成功!
注:因为本机只有一个组[ccdoop],故用all,若是有多个机组,而你只想测试一个组的话能够把all替换为组名,如: