playbook介绍

一. 为什么引入playbook

我们完成一个任务,例如安装部署一个httpd服务,我们需要多个模块(一个模块也可以称之为task)提供功能来完成。而playbook就是组织多个task的容器,他的实质就是一个文件,有着特定的组织格式,它采用的语法格式是YAML(Yet Another Markup Language)。YAML语法能够简单的表示散列表,字典等数据结构。具体请参考YAML详细语法

YAML基本语法

列表:每一个列表成员前面都要有一个短横线和一个空格

  1. fruits:
  2. - Apple
  3. - Orange
  4. - Strawberry
  5. - Mango
  6. 或者:
  7. fruits: ['Apple', 'Orange', 'Strawberry', 'Mango']

字典:每一个成员由键值对组成,注意冒号后面要有空格

  1. martin:
  2. name: Martin D'vloper
  3. job: Developer
  4. skill: Elite
  5. 或者
  6. martin: {name: Martin D'vloper, job: Developer, skill: Elite}

列表和字典可以混合使用

  1. - martin:
  2. name: Martin D'vloper
  3. job: Developer
  4. skills:
  5. - python
  6. - perl
  7. - pascal
  8. - tabitha:
  9. name: Tabitha Bitumen
  10. job: Developer
  11. skills:
  12. - lisp
  13. - fortran
  14. - erlang

二. playbook基础组件

  • Hosts:运行执行任务(task)的目标主机
  • remote_user:在远程主机上执行任务的用户
  • tasks:任务列表
  • handlers:任务,与tasks不同的是只有在接受到通知时才会被触发
  • templates:使用模板语言的文本文件,使用jinja2语法。
  • variables:变量,变量替换{{ variable_name }}

整个playbook是以task为中心,表明要执行的任务。hosts和remote_user表明在哪些远程主机以何种身份执行。其他组件让其能够更加灵活。

下面详细介绍某些组件

1. variable

变量定义在资产(inventory)中:

  1. 主机变量:
  2. 192.168.200.136 http_port=808 maxRequestsPerChild=808
  3. 192.168.200.137 http_port=8080 maxRequestsPerChild=909
  4. 主机组变量:
  5. [websers]
  6. 192.168.200.136
  7. 192.168.200.137
  8. [websers:vars]
  9. ntp_server=ntp.exampl.com
  10. proxy=proxy.exampl.com

变量定义在playbook中

  1. - hosts: webservers
  2. vars:
  3. http_port: 80

使用facts变量:

  1. facts变量是由setup模块获取远程主机的信息。
  2. 用法:
  3. ansible 192.168.200.136 -m setup

在roles中定义变量

  1. 后面介绍

ansible-playbook 命令中传入参数

  1. 使用 -e选项传入参数
  2. ansible-playbook 192.168.200.136 -e "httpd_port=808" httpd04.yml

变量的引用

  1. {{ var_name }}

2. templates

它是一个模块功能,与copy不同的是他的文本文件采用了jinga2语法,

jinga2基本语法如下,

  1. 字面量:
  2. 字符串:使用单引号或双引号
  3. 数字:整型,浮点数
  4. 列表:{item1item2,...}
  5. 字典:{key1:value1,key2:value2,...}
  6. 布尔型:true/false
  7. 算术运算:
  8. +,-,*,/,//,%,**
  9. 比较运算:
  10. ==,!=,>,>=,<,<=
  11. 逻辑运算:
  12. andornot

注意:template只能在palybook中使用。

3. tasks

执行的模块命令

  1. 格式:
  2. action:模块参数(此种方式只在较新的版本中出现)
  3. module:参数(已键值对的形式出现)
  4. 每一个task都有一个名称,用于标记此任务。任务示例:
  5. name: install httpd
  6. yum: name=httpd state=present
  7. 注意:shellcommand没有参数,可在后面直接跟命令
  8. shell: ss -tnl | grep :80
  9. 1)某任务的运行状态为changed后,可通过相应的notify通知相应的handlers
  10. 2)任务可以通过tags打标签,然后通过palybook命令-t选项调用.

三. playbook调用方式

  1. 用法:
  2. ansible-playbook <filename.yml> ... [options]
  3. <filename.yml>:yaml格式的playbook文件路径,必须指明
  4. [options]: 选项
  5. -C, --check:并不在远程主机上执行,只是测试。
  6. -i PATH, --inventory=PATH:资产的文件路径
  7. --flush-cache:清楚fact缓存
  8. --list-hosts:列出匹配的远程主机,并不执行任何动作
  9. -t, TAGS, --tags=TAGS:运行指定的标签任务
  10. --skip-tags:跳过指定的notify,后面详细介绍。

四. palybook示例文件解析

1. 安装部署httpd服务-version1

资产文件

  1. ~] cat /etc/ansible/Hosts
  2. [webservers]
  3. 192.168.200.136 httpd_port=808
  4. 192.168.200.137 httpd_port=8088
  5. [test]
  6. 192.168.200.13[6:7]

httpd配置文件

  1. ~] grep ^Listen /etc/httpd/conf/httpd.conf
  2. Listen 808

palybook文件

  1. ~] cat /root/httpd01.yml
  2. - hosts: webservers
  3. remote_user: root
  4. tasks:
  5. - name: install httpd
  6. yum: name=httpd state=present
  7. - name: install configure file
  8. copy: src=httpd.conf dest=/etc/httpd/conf/
  9. - name: start httpd service
  10. service: name=httpd state=started

测试playbook

运行playbook

再次执行playbook

  1. ~]# yum install libselinux-python

从上图可以看出,192.168.200.136执行成功,而192.168.200.137启动服务时配置文件错误,这是因为拷贝过去的配置文件是centos7上的,而137这台主机是centos6,它安装的是httpd-2.2配置文件不兼容。此问题后面解决。

查看服务启动时的端口

2. 安装部署httpd服务-version2

copy命令拷贝配置文件时,无法对配置文件进行修改,不够灵活。接下来我们使用template拷贝文件,并使用主机变量设置httpd端口号

资产文件

  1. ~]# cat /etc/ansible/hosts
  2. [webservers]
  3. 192.168.200.136 httpd_port=8088
  4. [test]
  5. 192.168.200.13[6:7]

配置文件

  1. ~]# grep ^Listen httpd.conf.j2
  2. Listen {{ httpd_port }}

palybook文件

  1. ~]# cat httpd02.yml
  2. - hosts: 192.168.200.136
  3. remote_user: root
  4. tasks:
  5. - name: install httpd
  6. yum: name=httpd state=present
  7. - name: install configure file
  8. template: src=httpd.conf.j2 dest=/etc/httpd/conf/httpd.conf
  9. - name: start httpd service
  10. service: name=httpd state=started

运行playbook

由图可以看出,playbook中只将文件拷贝过去了,并没有重启服务,所以我们可以看到端口监听的依然是808而不是8088。此时我们需要在配置文件修改时触发一个任务,这就是handlers的用法,重新修改playbook文件。

重新修改YAML文件

  1. ~]# cat httpd02.yml
  2. - hosts: 192.168.200.136
  3. remote_user: root
  4. tasks:
  5. - name: install httpd
  6. yum: name=httpd state=present
  7. - name: install configure file
  8. notify: restart httpd service
  9. template: src=httpd.conf.j2 dest=/etc/httpd/conf/httpd.conf
  10. - name: start httpd service
  11. service: name=httpd state=started
  12. handlers:
  13. - name: restart httpd servcie
  14. service: name=httpd state=restarted

notify表明此task改变时,它会触发一个事件,此事件会调用name为restart httpd service的handlers task。

再次运行playbook

可以看到,此playbook执行了两个任务,一个是拷贝文件,一个是重启服务。也可以看到此时监听的端口不在是808而是8088

我们修改配置文件并重启服务,这是一个非常常见的操作。由上面我们看到,尽管我们只需执行两个task但我们把所有的任务都执行一遍,这会降低效率,我们可以使用tags来指定执行那个任务。

3. 指定执行任务

资产文件

注意,修改了端口号

  1. ~] cat /etc/ansibele/hosts
  2. [webservers]
  3. 192.168.200.136 httpd_port=8080
  4. [test]
  5. 192.168.200.13[6:7]

修改playbook文件

  1. ~]# cat httpd03.yml
  2. - hosts: 192.168.200.136
  3. remote_user: root
  4. tasks:
  5. - name: install httpd
  6. yum: name=httpd state=present
  7. - name: install configure file
  8. notify: restart httpd service
  9. tags: reinstall configure file
  10. template: src=httpd.conf.j2 dest=/etc/httpd/conf/httpd.conf
  11. - name: start httpd service
  12. service: name=httpd state=started
  13. handlers:
  14. - name: restart httpd service
  15. service: name=httpd state=restarted

执行playbook

由图可以看到,playbook只执行了拷贝文件,以及拷贝文件触发的重启服务事件。也可以看到服务开启的是8080端口。

五. ansible特性--判断和循环

在前面有一个问题没有解决就是centos6和centos7配置文件不兼容的问题,我们需要对其进行判断,不同的版本拷贝同的文件。

我们将lamp放在一台主机上时,我们需要安装多个程序包,写成一个一个的task显得效率不高,写的臃肿。我们可以使用循环来进行安装。

1 判断

以解决上面遗留的问题为例,如何让centos6的主机拷贝centos6的文件,让centos7的主机拷贝centos7的文件。
也可以使用变量来实现,此处不做演示

资产文件

  1. ~]# cat /etc/ansible/hosts
  2. [webservers]
  3. 192.168.200.136 httpd_port=8088
  4. 192.168.200.137 httpd_port=8080
  5. [test]
  6. 192.168.200.13[6:7]

playbook文件

其中的ansible_distribution_major_version是ansible收集的facts

测试playbook文件

跳过notify,让其不执行重启服务的操作,在执行playbook时使用 --skip-tags选项

值得注意的是,虽然没有执行重启,但拷贝配置文件也没有执行。

执行playbook

注意:他的语法格式类似jinja2。

2. 循环

playbook文件

执行playbook文件并查看

Ansible之playbook的使用的更多相关文章

  1. Ansible进阶--playbook的使用

    一.什么是playbooksplaybooks是ansible的脚本.如同shell脚本一样,它是控制远程主机的一系列命令的集合,通过YAML语言编写.执行一些简单的任务,我们可以使用ad-hoc命令 ...

  2. ansible基础-playbook剧本的使用

    ansible基础-playbook剧本的使用 作者:尹正杰  版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.YAML概述 1>.YAML的诞生 YAML是一个可读性高,用来表达数据序 ...

  3. Ansible之playbook的使用总结 - 运维笔记

    之前详细介绍了Ansible的安装, 配置, 以及Ansible常用模块的使用. 下面对Ansible的playbook用法做一小结. 为什么引入playbook?一般运维人员完成一个任务, 比如安装 ...

  4. ansible学习-playbook的YAML语法

    [一篇非常好的ansible参考博文] 初识Ansible http://liumissyou.blog.51cto.com/4828343/1616462 --------------------- ...

  5. 自动化运维工具——ansible剧本playbook(三)

    一.Playbook--Ansible剧本 playbook是由一个或多个 "play"组成的列表 play的主要功能在于将事先归并为一组的主机装扮成事先通过ansible中的ta ...

  6. Ansible基于playbook批量修改主机名实战

    Ansible基于playbook批量修改主机名 安装Ansible,相信这里也不用多说,大家都知道 说一下环境:这里的主机名是修改之后的,我先把其他两台的主机名改为别的 192.168.30.21 ...

  7. 利用ansible书写playbook在华为云上批量配置管理工具自动化安装ceph集群

    首先在华为云上购买搭建ceph集群所需云主机: 然后购买ceph所需存储磁盘 将购买的磁盘挂载到用来搭建ceph的云主机上 在跳板机上安装ansible 查看ansible版本,检验ansible是否 ...

  8. 利用ansible书写playbook搭建HAProxy+Keepalived+PXC负载均衡和高可用的PXC环境续

    ansible.playbook.haproxy.keepalived.PXC haproxy+keepalived双主模式调度pxc集群 HAProxy介绍 反向代理服务器,支持双机热备支持虚拟主机 ...

  9. Ansible 和 Playbook 暂存

    Ansible  和  Playbook 暂存 , 也是一个批量管理工具 自动化的批量管理工具 主机清单  HOST Inventory 模块插件  Playbooks 查看ansible的目录结构 ...

  10. ansible使用playbook的简单例子(ansible2.9.7)

    一,ansible使用playbook的优点 1,用ansible执行一些简单的任务,使用ad-hoc命令就可以解决问题 如果执行复杂的功能,需要大量的操作,执行的ad-hoc命令会不够方便,这时我们 ...

随机推荐

  1. C# foreach循环

    一.简介 foreach循环可以迭代数组或者一个集合对象 二.语法 foreach(数据类型  变量名  in  数组名) {     //语句块: } 循环运行的过程:每一次循环时,从集合中取出一个 ...

  2. Java Automic包下的AtomicInteger

    感谢这两位博主的文章,文章源于: https://www.cnblogs.com/chenpi/p/5375805.html https://blog.csdn.net/fanrenxiang/art ...

  3. mysql启动时出现ERROR 2003问题的解决方法

    目录 写在前面 问题描述 分析原因 问题解决 写在前面 今天,在打开Navicat Permium 链接MySQL 的时候出现Error 2003 的错误. 遂记录产生的原因以及解决方法. 问题描述 ...

  4. 浅谈Vue.js2.0核心思想

    Vue.js是一个提供MVVM数据双向绑定的库,专注于UI层面,核心思想是:数据驱动.组件系统. 数据驱动: Vue.js数据观测原理在技术实现上,利用的是ES5Object.defineProper ...

  5. bugku——普通的二维码(进制转换)

    题目地址:http://ctf.bugku.com/files/5e480ecb178711e82bc847a208e15b32/misc80.zip 就一张二维码图片,用一些在线工具识别是乱码,用Q ...

  6. 为什么MES实施起来效果不佳?

    原因一:我国制造业存在管理基础的先天不足 我国企业与发达国家企业在管理发展上,存在较大的差别.发达制造国家经历了管理探索.发展.成熟.再提高的全过程,从管理基础的奠定到思想认识的深刻程度,都是我国所无 ...

  7. MYSQL的修改表结构SQL语句

    更多java学习资料>>> 1.背景 使用sql语句对表结构进行修改 2.案例演示 案例:表结构 CREATE TABLE `login_user` ( `id` ) NOT NUL ...

  8. “GIS DICTIONARY A-Z” 查询页面开发(2)——INSERT INTO数据库

    今日工作:数据库连接.数据写入 一.数据库连接:使用了pymysql库 from G2_dataClean import defList import pymysql db = pymysql.con ...

  9. ubuntu16.04 共享文件夹之后 /mnt/hgfs目录下没有显示共享的文件夹

    root权限执行: apt-get install open-vm-tools vmhgfs-fuse .host:/ /mnt/hgfs

  10. <code> 标签 让一段计算机代码显示在网页中

    <code> 标签 解释:要让一段计算机代码显示在网页中,那么这段代码需要用<code> 标签包起来,不然他会被当作网页的代码被 运行. 例如: <code>< ...