ansible的脚本:playbook剧本

(一)playbook的组成部分

tasks

任务,包含要在主机上执行的操作,使用模块定义这些操作,每一个任务都是一个模块的调用

variables

变量,存储和传递数据(和shell脚本中的变量是一个意思),变量可以自定义,可以在playbook当中定义为全局变量,也可以外部传参

templates

模版,用于生成配置文件,模版是包含占位符的文件,占位符由ansible在执行时转换为变量值

handlers

处理器,当需要有变更的时候,可以执行触发器

roles

角色,是一种组织和封装playbook的,允许把相关的任务、变量、模版和处理器组织成一个可复用的单元

(二)tasks模版

1、实例模版1

1检查yml文件的语法是否正确:ansible-playbook test.yaml --syntax-check

2查看playbook运行会生成几个tasks:ansible-playbook test.yaml --list-task

(3)检查生效的目标主机(在哪台主机上生效):ansible-playbook test.yaml --list-hosts

(4)运行playbook:ansible-playbook test.yaml

(5)测试

(6)指定剧本演出(指定步骤开始安装):ansible-playbook test.yaml --start-at-task='install httpd'

(7)切换用户

①运行命令:ansible-playbook test.yaml -K

(8)指定用户执行:ansible-playbook test.yaml -u root -k

2、实例模版2

字典方式:key-value

"{ { hostvars[inventory_hostname]['ansible_default_ipv4']['address'] }}":表示获取目标主机的IP地址。

包含所有主机变量的字典

inventory_hostname

目标的主机名

ansible_default_ipv4

获取目标主机名

ansible_default_ipv4.address

获取目标主机的IP地址

(1)外部传参:ansible-playbook test1.yml -e 'username=haide1 groupname=yyy2

3、playbook之条件判断

(1)when:是一个比较常见的应用场景,实现满足条件即执行,不满足条件即跳过任务
①when:满足条件执行,不满足不执行

(2)取反

①inventory_hostname代替ansible_default_ipv4.address

(3)条件1:IP地址20就安装httpd,IP地址是30就安装nginx

4、playbook之循环(迭代)

ansible的循环格式

with_items

循环遍历(最常用)

with_together

列表组循环(组合输出),列表对应的列,以数据结合的方式循环

with_list

列表分组循环

with_lnested

相当于双重循环,第一层定义了循环的次数,第二层表示第一层中的每个元素会循环几次

(1)with_items:循环遍历
①第一种

②第二种

③第三种:区分列表

④在/opt目录下创建文件1、2、3、4、a、b、c、d

(2)with_together:列表组循环(组合输出)

(3)with-nested:列表里面的元素定义了循环的次数,第二层列表,相当于内循环

5、实例3

(1)创建文件、目录

(2)创建用户名:test1 test2;组名分别是:dn1 dn2(一一对应)

(三)playbook之template模块

1、template模版:jinja模版架构,通过模版可以实现向模版文件传参(Python转义),把占位符参数转到配置文件中去

①jinja:生产一个目标文本文件,传递变量到需要的配置文件当中,一般用于web开发

2、安装http,配置文件传参

1安装httpd服务

(2)修改文件(http.conf.j2)

①http.conf.j2中配置的是占位符(声明变量)

(3)修改文件(/etc/ansible/hosts)

①/etc/ansible/hosts中配置了主机的占位符名称和j2文件中的占位符一致(定义参数:占位符的参数声明好)

4配置playbook:template模版来把参数传给目标主机的配置文件

5测试查看

3、安装nginx、配置文件传参

 1yum -y install nginx

(四)tags模块

1、tags:标签模块,可以在playbook当中为任务设定标签(tags),在运行playbook时可以通过指定任务标签,来实现只运行设定的标签任务

2、任务标签的种类(所有任务的默认标签就是always)

always

不管是否指定了运行标签,任务都会执行

never

即使运行了指定标签,该任务也不会执行

debug

调式任务

setup

收集主机信息

自定义

自定义标签

per_tasks

允许指定标签之前的任务

post_tasks

允许指定标签之后的任务

3、实例

1)ansible-playbook test4.yml --tags="debug"

2)ansible-playbook test4.yml --tags="never"

3自定义

4、在目标主机上touch文件/opt/hyde.txt always,在目标主机copy文件/opt/hyde1.txt never,第一次允许playbook不指定标签查看,第二次指定标签为never查看

(五)roles模块

1、角色模块:在ansible中roles模块是一个层次化、结构化的组织playbook,使用了roles(角色),可以根据层次结构,自动装载变量文件、task、以及handlers等等

2、roles:分别把变量、文件、任务、模块以及处理器,放在单独的目录中,使用roles模块来一键调用这些文件

3、roles的结构

roles——web——总目录,角色

files

存放copy和script模块调用的文件

templates

存放j2的模版文件

tasks

包含任务的目录,子文件:main.yml(角色运行的任务)

handlers

包含处理器的目录,子文件:main.yml

vars

存放变量的目录,子文件:main.yml

defaults

包含默认变量的目录,子文件:main.yml

meta

包含元信息的目录,子文件:main.yml(可以不写)

site.yml

在role目录下,用来调用所有的配置文件

4、实例

三个服务

http

mysql

php

1创建目录、文件
①mkdir files templates tasks handlers vars defaults meta

②touch {defaults,vars,tasks,meta,handlers}/main.yml

2声明任务和变量
①httpd

②mysql

③php

3编写site.yml,调用所有的配置文件

4检查

相关推荐

  1. ansible脚本playbook剧本

    2023-12-21 23:52:02       32 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-21 23:52:02       19 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-21 23:52:02       20 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-21 23:52:02       20 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-21 23:52:02       20 阅读

热门阅读

  1. hive(2)

    2023-12-21 23:52:02       29 阅读
  2. 自定义ORM(mybatis)源码(二)-解析mapper.xml

    2023-12-21 23:52:02       38 阅读
  3. Linux多线程

    2023-12-21 23:52:02       54 阅读
  4. 指针的进阶

    2023-12-21 23:52:02       25 阅读