CentOS 6.5 Ansible详细部署
一、ansible介绍
1、简介
ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet、cfengine、chef、func、fabric)的优点,实现了批量系统配置、批量程序部署、批量运行命令等功能。ansible是基于模块工作的,本身没有批量部署的能力。真正具有批量部署的是ansible所运行的模块,ansible只是提供一种框架。主要包括:
(1)、连接插件connection plugins:负责和被监控端实现通信;
(2)、host inventory:指定操作的主机,是一个配置文件里面定义监控的主机;
(3)、各种模块核心模块、command模块、自定义模块;
(4)、借助于插件完成记录日志邮件等功能;
(5)、playbook:剧本执行多个任务时,非必需可以让节点一次性运行多个任务。
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、任务执行流程
二、Ansible基础安装与配置
1、安装ansible
为了快速部署,我们这里不使用编译安装,我们使用epel源里面的rpm包
# yum install ansible
2、配置hosts文件
# vim /etc/ansible/hosts
我们可以看到有好多事例,我们可以注释掉他们,或者删掉他们,我们这里注释掉他们,在vim模式下
:%s/^\([^[:space:]#]\)/#\1/g
然后添加我们需要操作的主机,假设我就管理这两台主机。
1
2
3
|
[webserver] 10.0.0.16 10.0.0.13 |
3、配置主机无**登录
# ssh-copy-id -i ~/.ssh/id_rsa.pub 10.0.0.16
1
2
3
4
|
[email protected]'s password: Now try logging into the machine, with "ssh '10.0.0.16'" , and check in :
. ssh /authorized_keys
to make sure we haven 't added extra keys that you weren' t expecting.
|
三、案例测试
ansible <host-pattern> [-f forks] [-m module_name] [-a args]
1、对所管辖的主机进行Ping操作
# ansible all -m ping
1
2
3
4
5
6
7
8
9
|
10.0.0.13 | success >> { "changed" : false ,
"ping" : "pong"
} 10.0.0.16 | success >> { "changed" : false ,
"ping" : "pong"
} |
2、查看两台主机的时间
# ansible all -a 'date'
1
2
3
4
5
|
10.0.0.16 | success | rc=0 >> Tue Nov 17 15:57:16 CST 2015 10.0.0.13 | success | rc=0 >> Tue Nov 17 15:57:17 CST 2015 |
注:完整命令是ansible all -m command -a 'date',-m command默认可以省略
3、复制文件
命令ansible-doc -l可以查看很多可以操作的模块,具体查看某个模块操作用ansible-doc -s module,例如ansible-doc -s copy
# ansible webserver -m copy -a "src=/root/cmdline-jmxclient-0.10.3.jar dest=/root"
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
10.0.0.13 | success >> { "changed" : true ,
"checksum" : "98650e89f3c174b68971098618c2126b6cc1ab8b" ,
"dest" : "/root/cmdline-jmxclient-0.10.3.jar" ,
"gid" : 0,
"group" : "root" ,
"md5sum" : "ea665f2c562fc6aca3578cae46520b6d" ,
"mode" : "0644" ,
"owner" : "root" ,
"size" : 20124,
"src" : "/root/.ansible/tmp/ansible-tmp-1447747792.14-265823444157691/source" ,
"state" : "file" ,
"uid" : 0
} 10.0.0.16 | success >> { "changed" : true ,
"checksum" : "98650e89f3c174b68971098618c2126b6cc1ab8b" ,
"dest" : "/root/cmdline-jmxclient-0.10.3.jar" ,
"gid" : 0,
"group" : "root" ,
"md5sum" : "ea665f2c562fc6aca3578cae46520b6d" ,
"mode" : "0644" ,
"owner" : "root" ,
"size" : 20124,
"src" : "/root/.ansible/tmp/ansible-tmp-1447747792.15-265197722191280/source" ,
"state" : "file" ,
"uid" : 0
} |
本文转自 wzlinux 51CTO博客,原文链接:http://blog.51cto.com/wzlinux/1713543,如需转载请自行联系原作者