ansible的脚本:playbook剧本

(一)playbook的组成部分

tasks

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

variables

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

templates

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

handlers

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

roles

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

(二)tasks模版

1、实例模版1

ansible的脚本:playbook剧本_第1张图片

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

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

ansible的脚本:playbook剧本_第2张图片

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

ansible的脚本:playbook剧本_第3张图片

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

ansible的脚本:playbook剧本_第4张图片

(5)测试

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

ansible的脚本:playbook剧本_第5张图片

(7)切换用户

ansible的脚本:playbook剧本_第6张图片

ansible的脚本:playbook剧本_第7张图片

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

ansible的脚本:playbook剧本_第8张图片

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

ansible的脚本:playbook剧本_第9张图片

2、实例模版2

字典方式:key-value

ansible的脚本:playbook剧本_第10张图片ansible的脚本:playbook剧本_第11张图片

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

包含所有主机变量的字典

inventory_hostname

目标的主机名

ansible_default_ipv4

获取目标主机名

ansible_default_ipv4.address

获取目标主机的IP地址

ansible的脚本:playbook剧本_第12张图片

ansible的脚本:playbook剧本_第13张图片

ansible的脚本:playbook剧本_第14张图片

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

ansible的脚本:playbook剧本_第15张图片

ansible的脚本:playbook剧本_第16张图片

ansible的脚本:playbook剧本_第17张图片

ansible的脚本:playbook剧本_第18张图片

ansible的脚本:playbook剧本_第19张图片

3、playbook之条件判断

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

ansible的脚本:playbook剧本_第20张图片

ansible的脚本:playbook剧本_第21张图片

(2)取反

ansible的脚本:playbook剧本_第22张图片

ansible的脚本:playbook剧本_第23张图片

①inventory_hostname代替ansible_default_ipv4.address

ansible的脚本:playbook剧本_第24张图片

ansible的脚本:playbook剧本_第25张图片

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

ansible的脚本:playbook剧本_第26张图片

ansible的脚本:playbook剧本_第27张图片

4、playbook之循环(迭代)

ansible的循环格式

with_items

循环遍历(最常用)

with_together

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

with_list

列表分组循环

with_lnested

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

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

ansible的脚本:playbook剧本_第28张图片

ansible的脚本:playbook剧本_第29张图片

②第二种

ansible的脚本:playbook剧本_第30张图片

ansible的脚本:playbook剧本_第31张图片

③第三种:区分列表

ansible的脚本:playbook剧本_第32张图片

ansible的脚本:playbook剧本_第33张图片

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

ansible的脚本:playbook剧本_第34张图片

ansible的脚本:playbook剧本_第35张图片

ansible的脚本:playbook剧本_第36张图片

ansible的脚本:playbook剧本_第37张图片

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

ansible的脚本:playbook剧本_第38张图片

ansible的脚本:playbook剧本_第39张图片

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

ansible的脚本:playbook剧本_第40张图片

ansible的脚本:playbook剧本_第41张图片

ansible的脚本:playbook剧本_第42张图片

ansible的脚本:playbook剧本_第43张图片

5、实例3

(1)创建文件、目录

ansible的脚本:playbook剧本_第44张图片

ansible的脚本:playbook剧本_第45张图片

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

ansible的脚本:playbook剧本_第46张图片

ansible的脚本:playbook剧本_第47张图片

(三)playbook之template模块

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

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

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

1安装httpd服务

ansible的脚本:playbook剧本_第48张图片

ansible的脚本:playbook剧本_第49张图片

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

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

ansible的脚本:playbook剧本_第50张图片

ansible的脚本:playbook剧本_第51张图片

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

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

ansible的脚本:playbook剧本_第52张图片

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

ansible的脚本:playbook剧本_第53张图片

ansible的脚本:playbook剧本_第54张图片

5测试查看

ansible的脚本:playbook剧本_第55张图片

ansible的脚本:playbook剧本_第56张图片

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

 1yum -y install nginx

ansible的脚本:playbook剧本_第57张图片

ansible的脚本:playbook剧本_第58张图片

ansible的脚本:playbook剧本_第59张图片

ansible的脚本:playbook剧本_第60张图片

ansible的脚本:playbook剧本_第61张图片

(四)tags模块

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

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

always

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

never

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

debug

调式任务

setup

收集主机信息

自定义

自定义标签

per_tasks

允许指定标签之前的任务

post_tasks

允许指定标签之后的任务

3、实例

ansible的脚本:playbook剧本_第62张图片ansible的脚本:playbook剧本_第63张图片

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

ansible的脚本:playbook剧本_第64张图片

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

ansible的脚本:playbook剧本_第65张图片

3自定义

ansible的脚本:playbook剧本_第66张图片

ansible的脚本:playbook剧本_第67张图片

ansible的脚本:playbook剧本_第68张图片

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

ansible的脚本:playbook剧本_第69张图片

ansible的脚本:playbook剧本_第70张图片

ansible的脚本:playbook剧本_第71张图片

ansible的脚本:playbook剧本_第72张图片

(五)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

ansible的脚本:playbook剧本_第73张图片

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

ansible的脚本:playbook剧本_第74张图片

2声明任务和变量
①httpd

ansible的脚本:playbook剧本_第75张图片

②mysql

ansible的脚本:playbook剧本_第76张图片

ansible的脚本:playbook剧本_第77张图片

ansible的脚本:playbook剧本_第78张图片

③php

ansible的脚本:playbook剧本_第79张图片

ansible的脚本:playbook剧本_第80张图片

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

ansible的脚本:playbook剧本_第81张图片

ansible的脚本:playbook剧本_第82张图片

ansible的脚本:playbook剧本_第83张图片

4检查

ansible的脚本:playbook剧本_第84张图片

ansible的脚本:playbook剧本_第85张图片

ansible的脚本:playbook剧本_第86张图片

你可能感兴趣的:(ansible)