Ansible playbook

目录

1.1        playbook简介… 1

1.2        Playbook使用场景… 1

1.3        playbook格式… 2

1.4        playbook语法介绍… 3

1.5        Playbook执行结果解析… 4

1.5.1      收集facts 5

1.5.2      执行tasks 6

1.5.3      报告结果… 6

1.6        ansible-playbook实战小技巧… 6

1.6.1      例子一… 7

1.6.2      例子二… 7

1.6.3      例子三… 8

1.1       playbook简介

playbookansible用于配置,部署,和管理被控节点的剧本。通过playbook的详细描述,执行其中的一系列tasks,可以让远端主机达到预期的状态。playbook就像Ansible控制器给被控节点列出的的一系列to-do-list,而被控节点必须要完成。

也可以这么理解,playbook 字面意思,即剧本,现实中由演员按照剧本表演,在Ansible中,这次由计算机进行表演,由计算机安装,部署应用,提供对外服务,以及组织计算机处理各种各样的事情。

1.2      Playbook使用场景

执行一些简单的任务,使用ad-hoc命令可以方便的解决问题,但是有时一个设施过于复杂,需要大量的操作时候,执行的ad-hoc命令是不适合的,这时最好使用playbook,就像执行shell命令与写shell脚本一样,也可以理解为批处理任务,不过playbook有自己的语法格式,一会会介绍。

使用playbook你可以方便的重用这些代码,可以移植到不同的机器上面,像函数一样,最大化的利用代码。在你使用Ansible的过程中,你也会发现,你所处理的大部分操作都是编写playbook

1.3      playbook格式

       playbookYMAL语言编写。YAML参考了其他多种语言,包括:XMLC语言、PythonPerl以及电子邮件格式RFC2822Clark Evans20015月在首次发表了这种语言,另外Ingy döt NetOren Ben-Kiki也是这语言的共同设计者。

YMAL格式是类似于JSON的文件格式,便于人理解和阅读,同时便于书写。首先学习了解一下YMAL的格式,对我们后面书写playbook很有帮助。以下为playbook常用到的YMAL格式。

l  文件的第一行应该以 ”—” (三个连字符)开始,表明YMAL文件的开始。

l  在同一行中,#之后的内容表示注释,类似于shell,python和ruby。

l  YMAL中的列表元素以”-”开头然后紧跟着一个空格,后面为元素内容。就像这样

- apple
- banana
- orange

等价于JSON的这种格式

[
 “apple”,
 “banana”,
 “orange”
]

l  同一个列表中的元素应该保持相同的缩进。否则会被当做错误处理。

l  play中hosts,variables,roles,tasks等对象的表示方法都是键值中间以”:”分隔表示,”:”后面还要增加一个空格。

l  YMAL的有很多的字符串可以解释为true或false:

    YMAL Truhy: true ,  True ,  TRUE ,  yes ,  Yes ,  YES ,  on ,  On ,  ON ,  y ,

    YMAL falthy: false ,  False ,  FALSE ,  no ,  No ,  NO ,  off ,  Off ,  OFF ,  n ,  N

样例如下:

Ansible playbook

关于YMAL的更多信息,请参考

http://baike.baidu.com/link?url=10WYbxN7mNFp1I3Dq4ZD0RyhSeBWDYMfe8OOyjWyZMweFnze7eunGEWQNqypT9vXABeysp798Ld16g9qtvTWtq#1_1

1.4      playbook语法介绍

对比上述格式,下面我们看一个安装部署mysql服务的案例。Ansible playbook

mysql.yml中,主要由三个部分组成。

hosts部分:使用hosts指示使用哪个主机或主机组来运行下面的tasks,每个playbook都必须指定hostshosts也可以使用通配符格式。主机或主机组在inventory清单中指定,可以使用系统默认的/etc/ansible/hosts,也可以自己编辑,在运行的时候加上-i选项,指定清单的位置即可。在运行清单文件的时候,–list-hosts选项会显示那些主机将会参与执行task的过程中。

remote_user:指定远端主机中的哪个用户来登录远端系统,在远端系统执行task的用户,可以任意指定,也可以使用sudo,但是用户必须要有执行相应task的权限。

tasks:指定远端主机将要执行的一系列动作。tasks的核心为ansible的模块,前面已经提到模块的用法。tasks包含name和要执行的模块,name是可选的,只是为了便于用户阅读,不过还是建议加上去,模块是必须的,同时也要给予模块相应的参数。

1.5      Playbook执行结果解析

使用ansible-playbook运行playbook文件,得到如下输出信息,输出内容为JSON格式。并且由不同颜色组成,便于识别。一般而言

绿色代表执行成功,系统保持原样

黄色代表系统代表系统状态发生改变

红色代表执行失败,显示错误输出。

Ansible playbook

在被控节点可以看到软件包已经安装并且mysqld服务以及启动。

Ansible playbook

对比playbook文件内容与执行结果,可以得出playbook的执行步骤。

Ansible playbook

下面依次分析执行步骤

1.5.1    收集facts

首先默认的第一个task就是收集远端被管主机的ansible元数据信息,也被称为factsfacts信息包括,远端主机发行版,IP地址,CPU核数,系统架构,主机名等等,然后这些元数据可以作为变量供后面的task使用。你可以使用如下命令查看元数据的具体信息。

ansible <hostpattern> -m setup [-i inventory_file]

如下所示

Ansible playbook

在你执行的过程中,你会看到有大量的facts信息,这里我只是截取一小部分。你也可以禁止ansible收集facts,在playbook中的hosts指令下面设置gather_facts指令即可。如下

Ansible playbookAnsible playbook

facts经常被用在条件语句模板当中,也可以用于根据指定的标准根据group_by模块创建动态主机组,我们后面会详细介绍,这里我简单列出一个facts的用法实例,使用条件判断语句关闭指定发行版的主机。

Ansible playbook

1.5.2    执行tasks

这里为实际执行的task,每个任务都给出了它们的执行状态,是否改变了机器的状态。

Ansible playbook

我们可以看到每个task都有自己定义的名称,我们也可以去除task的名称。Ansible playbook

然后查看输出信息

Ansible playbook

可以看到task没有名称了,一般我们建议使用name来标示任务,便于人更好的阅读。

1.5.3    报告结果

执行结果报告。第一次运行,系统状态改变了两次。

Ansible playbook

第二次运行,系统状态不再发生改变,这也说明了,ansible的幂等性,我们可以多次的重复执行一个playbook。而不用考虑系统重复执行task

Ansible playbook

1.6      ansible-playbook实战小技巧

上面执行playbook的过程中,我们使用了ansile-playbook命令,为了灵活的控制playbookansible提供了ansible-playbook命令行工具,可以一些调整playbook执行流的选项,这里举出一些有用的实例。更多用法请参考ansible-playbook –h

1.6.1    例子一

查看当前任务,然后指定从哪里开始执行任务

Ansible playbook

Ansible playbook

1.6.2    例子二

执行或者跳过playbook中指定的tag,修改mysql.yml增加tags指令。

Ansible playbook

如下,结果,可以知道—tags—skip-tags的区别。

Ansible playbook

1.6.3    例子三

使用—step来一步一步的确认命令。

Ansible playbook

提示:如果你感觉输出信息不够详细,使用-v选项,使用-vv选项,信息更加详细,信息最详细的为-vvvv选项,自行尝试。

 

回顾下今天所讲内容:

1、  playbook是什么

2、  playbook的基本格式

3、  playbook剧本组成

4、  playbook执行过程

5、  ansibel-playbook的几个基本案例

 

原创文章,作者:艾贺,如若转载,请注明出处:http://www.178linux.com/9570

(0)
艾贺艾贺
上一篇 2015-12-06 20:36
下一篇 2015-12-07 10:10

相关推荐

  • 高级文件系统管理 之RAID

    高级文件系统管理 之RAID 软RAID  mdadm:为软RAID提供管理界面                  为空余磁盘添加冗余       &nb…

    Linux干货 2016-08-30
  • N25第一周作业

    第一周作业 一、计算机由硬件系统和软件系统两部分组成如下: 计算机硬件由CPU、内存、输入设备、输出设备组成。 1、中央处理器(CPU,Central Processing Unit)   CPU的功能主要是对输入指令的判断和运算;CPU包括运算器、控制器和寄存器三部分; (1)、运算器   执行各种算术和逻辑运算操作,计算机运行时,运算…

    Linux干货 2016-12-05
  • gzip压缩算法

    gzip,zlib,以及图形格式png,使用的是同一个压缩算法deflate。我们通过对gzip源码的分析来对deflate压缩算法做一个详细的说明: 第一,gzip压缩算法基本原理的说明。 第二,gzip压缩算法实现方法的说明。 第三,gzip实现源码级的说明。 1. Gzip压缩算法的原理      &n…

    Linux干货 2015-07-30
  • 系统管理之网络管理

    今天给大家分享一些网络方面的知识,,这块的知识很重要哦,都是涉及网络最底层的链路和协议,是我们学习大型服务的基础,和前提.希望大家努力理解这方面的内容,今天的内容大概有这几方面: 1.计算机网络概念 2.计算机网络体系结构 3.物理层 4.数据链路层 5.网络层 6.IP地址及子网 7.传输层 8.应用层 计算机网络概念 计算机网络是个发展中的概念和技术,具…

    Linux干货 2016-09-05
  • httpd配置

    httpd配置 修改监听的IP和端口(port) 持久连接 MPM DSO(Dynamic Shared Object) main server的文档页面路径 站点访问控制 定义站点主页面 定义路径别名 设定默认字符集 日志 基于用户的访问控制 虚拟主机 httpd状态页面 使用压缩模块mod_daflate优化速度 基于IP 为每个虚拟主机至少准备一个IP…

    Linux干货 2016-12-21
  • 浅谈Linux终端类型

    Linux终端类型 作者:任飞鹏            日期:2016-10-13 终端是什么: 终端(Terminal)也称终端设备,是计算机网络中处于网络最外围的设备,主要用于用户信息的输入以及处理结果的输出等。 早期计算机系统中,由于计算机主机…

    Linux干货 2016-10-19