一、管理大型的playbook

1️⃣:如果playbook很长或很复杂,我们可以将其分成较小的文件以便于管理

2️⃣:可采用模块化方式将多个playbook组合为一个主要playbook,或者将文件中的任务列表插入play

二、包含或导入文件

1️⃣:Ansible可以使用两种操作将内容带入playbook。可以包含内容,也可以导入内容

  • 包含内容是一个动态操作。在playbook运行期间,Ansible会在内容到达时处理所包含的内容
  • 导入内容是一个静态操作。在运行开始之前,Ansible在最初解析playbook时预处理导入的内容

三、导入plyabook

1️⃣:import_playbook指令允许将包含play列表的外部文件导入playbook。换句话说,可以把一个或多个额外playbook文件导入到主playbook文件

2️⃣:由于导入的内容是一个完整的playbook,因此import_playbook功能只能在playbook的顶层使用,不能在play内使用。如果导入多个playbook,则将按顺序导入并运行它们

3️⃣:导入两个额外playbook的主playbook的简单示例如下所

  • 实例模板:

    [root@localhost project]# cat playbook.yml
    ---
    - hosts: all
    tasks:
    - name: install httpd
    import_playbook: http.yml - name: start httpd
    import_playbook: start_http.yml
  • 演示实例

     //在playbook目录下创创建两个需要导入的playbook
    [root@localhost project]# cat playbook/install.yml
    ---
    - hosts: all
    tasks:
    - name: install httpd
    yum:
    name: httpd
    state: present
    [root@localhost project]# cat playbook/start.yml
    ---
    - hosts: all
    tasks:
    - name: start httpd
    service:
    name: httpd
    state: started //查看需要执行的playbook文件
    [root@localhost project]# cat play.yml
    ---
    - hosts: all
    tasks:
    - name: install httpd
    import_playbook: playbook/install.yml - name: start httpd
    import_playbook: playbook/start.yml //查看层级关系
    [root@localhost project]# tree .
    .
    ├── inventory
    ├── playbook
    │   ├── install.yml
    │   └── start.yml
    └── play.yml 1 directory, 4 files //执行playbook
    [root@localhost project]# ansible-playbook play.yml
    PLAY [all] **************************************************************************************************************************************************************** TASK [Gathering Facts] ****************************************************************************************************************************************************
    ok: [192.168.121.81] PLAY [all] **************************************************************************************************************************************************************** TASK [Gathering Facts] ****************************************************************************************************************************************************
    ok: [192.168.121.81] TASK [install httpd] ******************************************************************************************************************************************************
    changed: [192.168.121.81] PLAY [all] **************************************************************************************************************************************************************** TASK [Gathering Facts] ****************************************************************************************************************************************************
    ok: [192.168.121.81] TASK [start httpd] ********************************************************************************************************************************************************
    changed: [192.168.121.81] PLAY RECAP ****************************************************************************************************************************************************************
    192.168.121.81 : ok=5 changed=2 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0

四、包含和导入任务

1、导入任务文件

1️⃣:可以使用import_tasks功能将任务文件静态导入playbook内的play中。

2️⃣:导入任务文件时,在解析该playbook时将直接插入该文件中的任务。

3️⃣:Playbook中的import_tasks的位置控制插入任务的位置以及运行多个导入的顺序

  • 简单实例模板:

    [root@localhost project]# cat playbook.yml
    ---
    - hosts: all
    tasks:
    - name: install httpd
    import_tasks: http.yml - name: start httpd
    import_tasks: start_http.yml
  • 演示实例一:

     //查看playbook目录下写的需要导入的任务文件
    [root@localhost project]# cat playbook/install.yml
    - name: install httpd
    yum:
    name: httpd
    state: present
    [root@localhost project]# cat playbook/start.yml
    - name: start httpd
    service:
    name: httpd
    state: started //查看playbook主要执文件
    [root@localhost project]# cat play.yml
    ---
    - hosts: all
    tasks:
    - name: install httpd
    import_tasks: playbook/install.yml - name: start httpd
    import_tasks: playbook/start.yml //查看层级关系
    [root@localhost project]# tree .
    .
    ├── inventory
    ├── playbook
    │   ├── install.yml
    │   └── start.yml
    └── play.yml 1 directory, 4 files //执行playbook
    [root@localhost project]# ansible-playbook play.yml
    PLAY [all] **************************************************************************************************************************************************************** TASK [Gathering Facts] ****************************************************************************************************************************************************
    ok: [192.168.121.81] TASK [install httpd] ******************************************************************************************************************************************************
    changed: [192.168.121.81] TASK [start httpd] ********************************************************************************************************************************************************
    changed: [192.168.121.81] PLAY RECAP ****************************************************************************************************************************************************************
    192.168.121.81 : ok=3 changed=2 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0
  • 注意import_tasks和import_playbook处于不同的级别;import_playbook是与tasks平级;import_tasks则是tasks的子任务
  • 演示实例二:使用import_playbookimport_tasks混合使用

     //查看playbook目录下的需要导入的playbook文件和任务文件
    [root@localhost project]# cat playbook/install.yml
    - name: install httpd
    yum:
    name: httpd
    state: present
    [root@localhost project]# cat playbook/start.yml
    ---
    - hosts: all
    tasks:
    - name: start httpd
    service:
    name: httpd
    state: started //查看主要执行文件
    [root@localhost project]# cat play.yml
    ---
    - hosts: all
    tasks:
    - name: install httpd
    import_tasks: playbook/install.yml - name: start httpd
    import_playbook: playbook/start.yml //查看层级关系
    [root@localhost project]# tree .
    .
    ├── inventory
    ├── playbook
    │   ├── install.yml
    │   └── start.yml
    └── play.yml 1 directory, 4 files //执行play
    [root@localhost project]# ansible-playbook play.yml
    PLAY [all] **************************************************************************************************************************************************************** TASK [Gathering Facts] ****************************************************************************************************************************************************
    ok: [192.168.121.81] TASK [install httpd] ******************************************************************************************************************************************************
    changed: [192.168.121.81] PLAY [all] **************************************************************************************************************************************************************** TASK [Gathering Facts] ****************************************************************************************************************************************************
    ok: [192.168.121.81] TASK [start httpd] ********************************************************************************************************************************************************
    changed: [192.168.121.81] PLAY RECAP ****************************************************************************************************************************************************************
    192.168.121.81 : ok=4 changed=2 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0
  • 注意:使用混合模式的时候,import_playbook不能是第一个执行,必须从第二个开始执行

4️⃣:导入任务文件时,在解析该playbook时将直接插入该文件中的任务。由于import_tasks在解析playbook时静态导入任务,因此对其工作方式有一些影响

  • 使用import_tasks功能时,导入时设置的when等条件语句将应用于导入的每个任务
  • 无法将循环用于import_tasks功能
  • 如果使用变量来指定要导入的文件的名称,则将无法使用主机或组清单变量

2、包含任务文件

1️⃣:可以使用include_tasks功能将任务文件动态导入playbook内的play

  • 简单实例模板:

    [root@localhost project]# cat playbook.yml
    ---
    - hosts: all
    tasks:
    - name: install httpd
    include_tasks: install_httpd.yml

2️⃣:在play运行并且这部分play到达前,include_tasks功能不会处理playbook中的内容

3️⃣:Playbook内容的处理顺序会影响包含任务功能的工作方式

  • 使用include_tasks功能时,包含时设置的when等条件语句将确定任务是否包含在play中
  • 如果运行ansible-playbook --list-tasks以列出playbook中的任务,则不会显示已包含任务文件中的任务
  • 相比之下,import_tasks功能不会列出导入任务文件的任务,而列出已导入任务文件中的各个任务
  • 不能使用ansible-playbook --start-at-task从已包含任务文件中的任务开始执行playbook
  • 不能使用notify语句触发已包含任务文件中的处理程序名称。可以在包含整个任务文件的主playbook中触发处理程序,在这种情况下,已包含文件中的所有任务都将运行

3、任务文明的用例

  1. 如果新服务器需要全面配置,则管理员可以创建不同的任务集合,分别用于创建用户、安装软件包、配置服务、配置特权、设置对共享文件系统的访问权限、强化服务器、安装安全更新,以及安装监控代理等。每一任务集合可通过单独的自包含任务文件进行管理
  2. 如果服务器由开发人员、系统管理员和数据库管理员统一管理,则每个组织可以编写自己的任务文件,再由系统经理进行审核和集成
  3. 如果服务器要求特定的配置,它可以整合为按照某一条件来执行的一组任务。换句话说,仅在满足特定标准时才包含任务
  4. 如果一组服务器需要运行某一项/组任务,则它/它们可以仅在属于特定主机组的服务器上运行

4、管理任务文件

为方便管理,可以创建专门用于任务文件的目录,并将所有任务文件保存在该目录中。然后playbook就可以从该目录包含或导入任务文件。这样就可以构建复杂的playbook,同时简化其结构和组件的管理

五、为外部play和任务定义变量

1️⃣:使用Ansible的导入和包含功能将外部文件中的play或任务合并到playbook中极大地增强了在Ansible环境中重用任务和playbook的能力

  • 演示实例:

     //查看所需要的导入的外部任务文件
    [root@localhost project]# cat playbook/install.yaml
    - name: install {{ package }}
    yum:
    name: "{{ package }}"
    state: present
    [root@localhost project]# cat playbook/service.yaml
    - name: start {{ package }} service
    service:
    name: "{{ package }}"
    state: started //查看变量文件
    [root@localhost project]# cat files/vars.yaml
    package: httpd //查看主要执行文件
    [root@localhost project]# cat playbook/main.yaml
    ---
    - hosts: all
    vars_files:
    ../files/vars.yaml
    tasks:
    - import_tasks: install.yaml
    - import_tasks: service.yaml //执行playbook
    [root@localhost project]# ansible-playbook playbook/main.yaml PLAY [all] **************************************************************************************************************************************************************** TASK [Gathering Facts] ****************************************************************************************************************************************************
    ok: [192.168.121.81] TASK [install httpd] ******************************************************************************************************************************************************
    changed: [192.168.121.81] TASK [start httpd service] ************************************************************************************************************************************************
    changed: [192.168.121.81] PLAY RECAP ****************************************************************************************************************************************************************
    192.168.121.81 : ok=3 changed=2 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0

2️⃣:使用相同的技术使play文件更具有可重用性。将play文件合并到playbook中时,传递变量以用于执行该play

  • 演示实例:

      //查看需要导入的外部playbook文件
    [root@localhost project]# cat playbook/mariadb.yaml
    ---
    - hosts: all
    vars_files:
    ../files/vars.yaml
    tasks:
    - name: install {{ package }}
    yum:
    name: "{{ package }}"
    state: present //查看变量文件
    [root@localhost project]# cat files/vars.yaml
    package: mariadb-server //查看主要执行的文件
    [root@localhost project]# cat playbook/main.yaml
    - name: isntall package
    import_playbook: mariadb.yaml //执行play
    [root@localhost project]# ansible-playbook playbook/main.yaml PLAY [all] **************************************************************************************************************************************************************** TASK [Gathering Facts] ****************************************************************************************************************************************************
    ok: [192.168.121.81] TASK [install mariadb-server] *********************************************************************************************************************************************
    changed: [192.168.121.81] PLAY RECAP ****************************************************************************************************************************************************************
    192.168.121.81 : ok=2 changed=1 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0

Ansible_包含和导入playbook文件的更多相关文章

  1. SharePoint 2013报错之“指定的文件不是有效的电子表格或者没有包含要导入的数据”

    当你尝试用SharePoint 2013中的“导入电子表格”功能时,可能会遇到报错“指定的文件不是有效的电子表格或者没有包含要导入的数据” 解决方法:只需要将你的SharePoint网址添加到浏览器的 ...

  2. java调用sqlldr导入csv文件数据到临时表

    package cn.com.file;import java.io.BufferedReader;import java.io.BufferedWriter;import java.io.File; ...

  3. 导入excel2007文件问题

    基于oledb方式导入excel2007文件时,使用如下链接字符串: string strCon = "Provider=Microsoft.ACE.OLEDB.12.0;Data Sour ...

  4. 导入.pch文件

    Xcode5中创建一个工程的时候,系统会自动创建一个以以工程名为名字的pch(Precompile Prefix Header)文件,开发的过程中可以将广泛使用的头文件以及宏包含在该文件下,编译器就会 ...

  5. 解决ubuntu server mysql load data infile 导入本地文件ERROR 1148 (42000)错误。

    问题:在ubuntu server 上使用apt-get 安装完 mysql 使用 load data infile 出现错误,错误代码如下: ERROR (): The used command i ...

  6. android NDK编译(导入).a文件和编译多个so文件(转)

    源:android NDK编译(导入).a文件和编译多个so文件 一.编译一个静态库 libstatic_android.a LOCAL_PATH := $(call my-dir) include ...

  7. Perl导入代码文件

    从函数复用开始:eval和do执行perl文件 当我们定义了一个功能比较通用的子程序,比如获取数值的绝对值.想要到处使用这个子程序,就得不断复制.粘贴这段绝对值函数的定义文本.显然,这是不太理想的方式 ...

  8. 从navicat中导入sql文件过大:Got a packet bigger than 'max_allowed_packet' bytes

    失败背景:刚才通过navicat向本地mysql数据库中导入sql文件.第一个sql文件(多个表)大小为967M,导入成功: 第二个sql(单个表)大小为50.1M,导入失败. 1.在navicat中 ...

  9. 【其他】【navicat】【1】navicat导入txt文件中文乱码问题解决

    正文: TXT文件默认编码为ANSI,另存为编码为UTF-8的文本文件即可 备注: 1,一般需要导入的数据都是一张excel表,需要将excel表另存为“文本文件(制表符分隔)(*.txt)”保存类型 ...

随机推荐

  1. [源码解析] 并行分布式任务队列 Celery 之 消费动态流程

    [源码解析] 并行分布式任务队列 Celery 之 消费动态流程 目录 [源码解析] 并行分布式任务队列 Celery 之 消费动态流程 0x00 摘要 0x01 来由 0x02 逻辑 in komb ...

  2. kestrel Server的源码分析

    今天这一篇博客讲的是.net core 自带的kestrel server,当你开发微服务k8s部署在linux环境下,一般默认开启这个高性能服务,如果大家之前看过我的owin katana的博客,会 ...

  3. dubbo支持哪些通信协议?支持哪些序列化协议?

    (1)dubbo支持不同的通信协议 1)dubbo协议 dubbo://192.168.0.1:20188 默认就是走dubbo协议的,单一长连接,NIO异步通信,基于hessian作为序列化协议 适 ...

  4. Go 包管理与依赖查找顺序

    目录 1. 规则: 2. 编译时的依赖包查找机制 3.vendor vendor的层级搜索 4. modules 1. 规则: 同一目录下只能存在一个包 目录和目录下源文件的包命名可以不同 当包名与目 ...

  5. Horovod-Usage

    Usage 代码中要包含以下6步: 初始化 Run hvd.init() to initialize Horovod. 将每个GPU固定到单个进程以避免资源争用. 一个线程一个GPU,设置到 loca ...

  6. 并发编程之ThreadLocal

    并发编程之ThreadLocal 前言 当多线程访问共享可变数据时,涉及到线程间同步的问题,并不是所有时候,都要用到共享数据,所以就需要线程封闭出场了. 数据都被封闭在各自的线程之中,就不需要同步,这 ...

  7. .Net Core 集成 Kafka

    最近维护的一个系统并发有点高,所以想引入一个消息队列来进行削峰.考察了一些产品,最终决定使用kafka来当做消息队列.以下是关于kafka的一些知识的整理笔记. kafka kafka 是分布式流式平 ...

  8. k8s集群移除node

    先drain节点上的pod 使用kubectl drain node03 --delete-local-data --force --ignore-daemonsets 之后删除node [root@ ...

  9. 阿里云 RTC QoS 弱网对抗之 LTR 及其硬件解码支持

    LTR 弱网对抗由于需要解码器的反馈,因此用硬件解码器实现时需要做一些特殊处理.另外,一些硬件解码器对 LTR 的实现不是特别完善,会导致出现解码错误.本文为 QoS 弱网优化系列的第三篇,将为您详解 ...

  10. 【cypress】5. 测试本地web应用

    在之前的cypress介绍里曾提到过,cypress虽然也可以测试部署好的应用,但是它最大的能力还是发挥在测试本地应用上. 本章主要内容就是关于如何测试本地web应用的概述: cypress与后台应用 ...