红帽秘笈,第三十章playbook的使用

本章主要介绍如何在ansible中写脚本。
playbook的语法
在写playbook时如何进行错误处理
ansible的许多模块都是在命令行中执行的,每次只能执行一个模块。如果需要执行多个
模块,且要写判断语句,判断模块是否执行成功了,如果没成功会怎么处理等。这时就需要
写脚本了,ansible中的脚本叫作 playbook,每个 playbook中可以包含多个 play。
在写playbook时,一定要先写好框架,然后往框架中写内容。如果在多个主机组上做的
是相同的操作,可以把它们放在同一个play中。如果在不同的主机组上做的是不同的操作,
可以通过不同的play分别来实现。
这里第二个play中加了一句gather_facts: false,意思是在执行此play时不需要通过setup
获取主机组的信息。所以,如果在tasks中没有使用到fact变量,建议加上这句,可以提升执
行的速度。
写好之后运行playbook的方法是ansible playbook文件。
本章实验都在/home/lduan/demol下操作,先把demo1目录创建出来并把 ansible.cfg
和hosts拷贝进去,命令如下。
练习1:写一个playbook文件test1.yaml,在server2和server3上打印主机名和IP。
分析:因为在server2和 server3上做的是相同的操作,所以只要一个play即可。这个play
中包含两个task: 一个用于打印主机名,另一个用于打印IP,命令如下。
红帽秘笈,第三十章playbook的使用_第1张图片

 

运行此playbook,命令如下。

[bdqn@rhel13 demo1]$ ansible-playbook test1.yaml 

练习2:写一个playbook文件test2.yaml,在server2上打印主机名,在server3上打印
IP。分析:因为在server2和 server3上做的是不同的操作,所以这里写两个play,一个play在
server2上执行,另一个play在server3上执行。每个play中只要包含一个task即可,命令如
下。
红帽秘笈,第三十章playbook的使用_第2张图片

 

运行此playbook,命令如下。

红帽秘笈,第三十章playbook的使用_第3张图片 

 

练习3:写一个playbook 文件 test3.yaml,要求如下。
(1)在server2上安装vsftpd,启动并开机自动启动vsftpd,设置防火墙开放ftp服务。
(2)在server3上安装 httpd,启动并开机自动启动httpd,设置防火墙开放http服务。
分析:因为在server2和 server3上做的是不同的操作,所以这里写两个play.
第一个play在server2上执行,包含3个task,分别用于安装、服务管理、防火墙设置。
第二个 play在server3上执行,包含3个task,分别用于安装、服务管理、防火墙设置。
红帽秘笈,第三十章playbook的使用_第4张图片

运行此playbook,命令如下。

红帽秘笈,第三十章playbook的使用_第5张图片 

 

在写playbook时,会遇到各种各样的问题,例如,命令出错了,或者引用的变量不存在
等。playbook具备一定的错误处理能力。
执行一个playbook时,如果其中的某个task出错,则后续的task就不再继续执行了。看
下面的例子,编写test4.yaml的内容如下。
红帽秘笈,第三十章playbook的使用_第6张图片

 

这里写了两个task,一个是aa,另一个是bb,aa这个 task 中引用了一个不存在的变量
default_xxx,所以导致aa这个task报错。如果某个task出错,则后续的task就不再继续执行
了,所以bb这个 task不会继续执行了
[bdqn@rhel13 demo1]$ ansible-playbook test4.yaml
fail模块和debug模块一样,都是用来打印信息的,区别在于debug执行完成之后会继续
进行后续模块的操作,而fail打印完报错信息之后会退出整个playbook。编写test5.yaml的
内容如下
红帽秘笈,第三十章playbook的使用_第7张图片

 

这里写了3个task,其中task aa和 task cc使用debug打印信息, task bb使用fail打印信
息。下面运行此playbook查看结果,如下所示。
红帽秘笈,第三十章playbook的使用_第8张图片

 

 

你可能感兴趣的:(ansible)