Ansible的playbook脚本使用

本章注意介绍如何在ansible中写脚本

  • playbook的语法
  • 在写playbook时如何进行错误处理

ansible的许多模块都是在命令行中执行的,每次只能执行一个模块。如果需要执行多个模块,且要写判断语句,判断模块是否执行成功了,如果没成功会怎么处理等。这时就需要写脚本了,ansible中的脚本叫作 playbook,每个 playbook中可以包含多个play

1.1  playbook的写法

playbook是以yaml或yml作为后缀,每个play都可以使用两种格式来写

(1)参数写在模块后面

- name: play的名称
hosts:主机组1,主机组2,....    //列出主机
tasks:
- name:提示信息1
模块1:argx1=vx1 argz2=vx2    //这种写法,“=”两边不要有空格
- name: 提示信息x
模块x: rgx1=vx1 argx2=vx2    

一个 play 中可以包含多个 tasks,每个 task调用一个模块

(2)参数分行写,一行一个参数

‐ hosts:主机组1,主机组2,... #‐‐列出主机组
tasks:
‐ name:描述语句1
模块1:
argxl: vxl #这里指定模块的参数,注意冒号后面的空格
argx2: vx2
‐ name:描述语句2
模块x:
argxl:vx1
argx2:vx2

需要注意的是,YAML文件对缩进有极严格的要求,每个缩进都是两个空格,不要按【Tab】键

一个完整的playbook中至少要包含一个 play,下面是一个包含两个play的playbook

‐‐‐
‐ name: 第一个play的名称
hosts: 主机组1,主机组2,...#‐‐列出主机组
tasks:
‐ name:提示信息1
模块1:argxl‐vxl argx2=vx2
‐ name:提示信息×
模块x:rgxl=vxl argx2=vx2
‐ name: 第二个play的名称
hosts: 主机组3,主机组4,...#‐‐列出主机组
gather facts: false
tasks:
‐ name: 提示信息1
模块1: argxl=vxl argx2=vx2
‐ name: 提示信息×
模块x: rgxl=vxl argx2=Vx2

在写playbook时,一定要先写好框架,然后往框架中写内容。如果在多个主机组上做的是相同的操作,可以把它们放在同一个play中。如果在不同的主机组上做的是不同的操作,可以通过不同的play分别来实现

这里第二个play中加了一句gather_facts: false,意思是在执行此play时不需要通过setup获取主机组的信息。所以,如果在tasks中没有使用到fact变量,建议加上这句,可以提升执行的速度

写好之后运行playbook的方法是ansible playbook文件

本章实验都在/home/lduan/demol下操作,先把demo1目录创建出来并把 ansible.cfg 和hosts拷贝进去

[jin@rhel801 ~]$ mkdir demo1
[jin@rhel801 ~]$ cp ansible.cfg hosts demo1/
[jin@rhel801 ~]$ cd demo1/
[jin@rhel801 demo1]$ ls
ansible.cfg  hosts
[jin@rhel801 demo1]$

练习1:写一个playbook文件test1.yaml,在rhel802和rhel803上打印主机名和IP

分析:因为在server2和 server3上做的是相同的操作,所以只要一个play即可。这个play中包含两个task: 一个用于打印主机名,另一个用于打印IP

[jin@rhel801 demo1]$ cat test1.yml 
---
- hosts: rhel802,rhel803tasks:- name: 打印主机名debug: msg={{ansible_fqdn}}- name: 打印IP地址debug: msg={{ansible_default_ipv4.address}}
[jin@rhel801 demo1]$

运行此playbook

[jin@rhel801 demo1]$ ansible-playbook test1.yml PLAY [rhel802,rhel803] *********************************************************TASK [Gathering Facts] *********************************************************
ok: [rhel802]
ok: [rhel803]TASK [打印主机名] *******************************************************************
ok: [rhel802] => {"msg": "rhel802"
}
ok: [rhel803] => {"msg": "rhel803"
}TASK [打印IP地址] ******************************************************************
ok: [rhel802] => {"msg": "192.168.161.17"
}
ok: [rhel803] => {"msg": "192.168.161.18"
}PLAY RECAP *********************************************************************
rhel802                    : ok=3    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0   
rhel803                    : ok=3    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0   [jin@rhel801 demo1]$

练习2:写一个playbook文件test2.yaml,在rhel802上打印主机名,在rhel803上打印 IP。

分析:因为在rhel802和 rhel803上做的是不同的操作,所以这里写两个play,一个play在 rhel802上执行,另一个play在rhel803上执行。每个play中只要包含一个task即可

[jin@rhel801 demo1]$ cat test2.yml 
---
- name: 在rhel802上的操作hosts: rhel802tasks: - name: 打印主机名debug: msg={{ansible_fqdn}}- name: 在rhel803上的操作hosts: rhel803tasks: - name: 打印IP地址debug: msg={{ansible_default_ipv4.address}}
[jin@rhel801 demo1]$

运行此playbook

[jin@rhel801 demo1]$ ansible-playbook test2.yml PLAY [在rhel802上的操作] ************************************************************TASK [Gathering Facts] *********************************************************
ok: [rhel802]TASK [打印主机名] *******************************************************************
ok: [rhel802] => {"msg": "rhel802"
}PLAY [在rhel803上的操作] ************************************************************TASK [Gathering Facts] *********************************************************
ok: [rhel803]TASK [打印IP地址] ******************************************************************
ok: [rhel803] => {"msg": "192.168.161.18"
}PLAY RECAP *********************************************************************
rhel802                    : ok=2    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0   
rhel803                    : ok=2    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0   [jin@rhel801 demo1]$

练习3:写一个playbook 文件 test3.yaml,要求如下

(1)在rhel802上安装vsftpd,启动并开机自动启动vsftpd,设置防火墙开放ftp服务

(2)在rhel803上安装 httpd,启动并开机自动启动httpd,设置防火墙开放http服务

分析:因为在server2和 server3上做的是不同的操作,所以这里写两个play

第一个play在rhel80r2上执行,包含3个task,分别用于安装、服务管理、防火墙设置

第二个 play在rhel803上执行,包含3个task,分别用于安装、服务管理、防火墙设置

[jin@rhel801 demo1]$ cat test3.yml 
---
- name: 在rhel802上要做的操作----安装vsftpd,启动服务,开启防火墙hosts: rhel802tasks: - name: 第一个操作安装vsftpdyum: name=vsftpd state=installed- name: 第二个操作启动服务service: name=vsftpd state=started enabled=yes- name: 第三个操作开启防火墙firewalld: service=ftp state=enabled immediate=yes permanent=yes- name: 在rhel803上要做的操作----安装httpd,启动服务,开启防火墙hosts: rhel803tasks:- name: 第一个操作安装httpdyum: name=httpd state=installed- name: 第二个操作启动服务service: name=httpd state=started enabled=yes- name: 第三个操作开启防火墙firewalld: service=http state=enabled immediate=yes permanent=yes
[jin@rhel801 demo1]$

运行此playbook 

[jin@rhel801 demo1]$ ansible-playbook test3.yml PLAY [在rhel802上要做的操作----安装vsftpd,启动服务,开启防火墙] ***********************************TASK [Gathering Facts] *********************************************************
ok: [rhel802]TASK [第一个操作安装vsftpd] ***********************************************************
ok: [rhel802]TASK [第二个操作启动服务] ***************************************************************
ok: [rhel802]TASK [第三个操作开启防火墙] **************************************************************
ok: [rhel802]PLAY [在rhel803上要做的操作----安装httpd,启动服务,开启防火墙] ************************************TASK [Gathering Facts] *********************************************************
ok: [rhel803]TASK [第一个操作安装httpd] ************************************************************
changed: [rhel803]TASK [第二个操作启动服务] ***************************************************************
changed: [rhel803]TASK [第三个操作开启防火墙] **************************************************************
changed: [rhel803]PLAY RECAP *********************************************************************
rhel802                    : ok=4    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0   
rhel803                    : ok=4    changed=3    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0   [jin@rhel801 demo1]$ 

1.2 错误处理

在写playbook时,会遇到各种各样的问题,例如,命令出错了,或者引用的变量不存在等。playbook具备一定的错误处理能力

1.2.1 ignore_errors

执行一个playbook时,如果其中的某个task出错,则后续的task就不再继续执行了。看 下面的例子,编写test4.yaml的内容如下

[jin@rhel801 demo1]$ cat test4.yml 
---
- hosts: rhel802gather_facts: falsetasks:- name: aadebug: msg={{default_aaa}}- name: bbdebug: msg="3333"
[jin@rhel801 demo1]$

 这里写了两个task,一个是aa,另一个是bb,aa这个 task 中引用了一个不存在的变量 default_aaa,所以导致aa这个task报错。如果某个task出错,则后续的task就不再继续执行了,所以bb这个 task不会继续执行了

[jin@rhel801 demo1]$ ansible-playbook test4.yml PLAY [rhel802] *****************************************************************TASK [aa] **********************************************************************
fatal: [rhel802]: FAILED! => {"msg": "The task includes an option with an undefined variable. The error was: 'default_aaa' is undefined\n\nThe error appears to be in '/home/jin/demo1/test4.yml': line 5, column 5, but may\nbe elsewhere in the file depending on the exact syntax problem.\n\nThe offending line appears to be:\n\n  tasks:\n  - name: aa\n    ^ here\n"}PLAY RECAP *********************************************************************
rhel802                    : ok=0    changed=0    unreachable=0    failed=1    skipped=0    rescued=0    ignored=0   [jin@rhel801 demo1]$

 如果想让task aa出错时不影响后续task的执行,那么可以在task aa中添加 ignore_errors:true来忽略这个报错继续往下执行

 这里添加了ignore_errors:true忽略报错信息。下面运行test4.yaml查看结果

[jin@rhel801 demo1]$ ansible-playbook test4.yml PLAY [rhel802] *****************************************************************TASK [aa] **********************************************************************
fatal: [rhel802]: FAILED! => {"msg": "The task includes an option with an undefined variable. The error was: 'default_aaa' is undefined\n\nThe error appears to be in '/home/jin/demo1/test4.yml': line 5, column 5, but may\nbe elsewhere in the file depending on the exact syntax problem.\n\nThe offending line appears to be:\n\n  tasks:\n  - name: aa\n    ^ here\n"}
...ignoringTASK [bb] **********************************************************************
ok: [rhel802] => {"msg": "3333"
}PLAY RECAP *********************************************************************
rhel802                    : ok=2    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=1   [jin@rhel801 demo1]$

可以看到,即使task aa出错了,但是后续的 task bb仍然继续执行

1.2.2 fail语句

fail模块和debug模块一样,都是用来打印信息的,区别在于debug执行完成之后会继续进行后续模块的操作,而fail打印完报错信息之后会退出整个playbook。编写test5.yaml的内容如下

[jin@rhel801 demo1]$ cat test5.yml 
---
- hosts: rhel802gather_facts: falsetasks:- name: aadebug: msg="111"- name: bbfail: msg="222"- name: ccdebug: msg="333"[jin@rhel801 demo1]$ 

这里写了3个task,其中task aa和 task cc使用debug打印信息, task bb使用fail打印信息。下面运行此playbook查看结果,如下所示

[jin@rhel801 demo1]$ ansible-playbook test5.yml PLAY [rhel802] *****************************************************************TASK [aa] **********************************************************************
ok: [rhel802] => {"msg": "111"
}TASK [bb] **********************************************************************
fatal: [rhel802]: FAILED! => {"changed": false, "msg": "222"}PLAY RECAP *********************************************************************
rhel802                    : ok=1    changed=0    unreachable=0    failed=1    skipped=0    rescued=0    ignored=0   [jin@rhel801 demo1]$

可以看到,task aa正确执行之后,继续执行task bb。因为 task bb用的是fail来打印信, 所以执行完成之后就退出 playbook了,task cc并没有执行

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/234323.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringBoot基于gRPC进行RPC调用

SpringBoot基于gRPC进行RPC调用 一、gRPC1.1 什么是gRPC?1.2 如何编写proto1.3 数据类型及对应关系1.4 枚举1.5 数组1.6 map类型1.7 嵌套对象 二、SpringBoot gRPC2.1 工程目录2.2 jrpc-api2.2.1 引入gRPC依赖2.2.2 编写 .proto 文件2.2.3 使用插件机制生产proto相关…

Java 基础学习(十四)Map集合与Set集合

1 Map集合 1.1 Map接口 1.1.1 Map接口概述 Map接口是一种双列集合。Map的每个元素都包含一个键对象Key和一个值对象Value ,键对象和值对象之间存在对应关系,这种关系称为映射(Mapping)。 Map接口中的元素,可以通过…

DC-6靶场

DC-6靶场下载: https://www.five86.com/downloads/DC-6.zip 下载后解压会有一个DC-3.ova文件,直接在vm虚拟机点击左上角打开-->文件-->选中这个.ova文件就能创建靶场,kali和靶机都调整至NAT模式,即可开始渗透 首先进行主…

【Transformer框架代码实现】

Transformer Transformer框架注意力机制框架导入必要的库Input Embedding / Out EmbeddingPositional EmbeddingTransformer EmbeddingScaleDotProductAttention(self-attention)MultiHeadAttention 多头注意力机制EncoderLayer 编码层Encoder多层编码块/前馈网络层…

【机器学习】密度聚类:从底层手写实现DBSCAN

【机器学习】Building-DBSCAN-from-Scratch 概念代码数据导入实现DBSCAN使用样例及其可视化 补充资料 概念 DBSCAN(Density-Based Spatial Clustering of Applications with Noise,具有噪声的基于密度的聚类方法)是一种基于密度的空间聚类算…

新手做抖店应该怎么做?应该注意些什么?踩坑避雷!

我是电商珠珠 新手做抖店,对于办理营业执照、选类目确定品,或是找达人这些,往往会在这上面吃很多亏。 我做抖店也已经三年了,关于抖店的玩法和规则这块也非常熟悉,这就来给大家讲讲我所踩的那些坑。 第一个&#xf…

自动化边坡监测设备是什么?

随着科技的不断进步,我们的生活和环境也在不断地发生变化。然而,自然灾害仍然是我们无法完全避免的风险。其中,边坡滑坡就是一种常见的自然灾害。为了保护人民的生命财产安全,科学家们研发出了自动化边坡监测设备。 WX-WY1 自动化…

亚信安慧AntDB数据库引领中文信息处理标准化创新

近期,亚信科技旗下的AntDB数据库再获殊荣,成功通过GB 18030-2022《信息技术中文编码字符集》最高实现级别(级别3)的检测认证,成为首批达到该认证标准的数据库产品之一。这一认证不仅是对AntDB数据库卓越技术实力的肯定…

算法02哈希法

算法01之哈希法 1.哈希法理论基础1.1哈希表(1)哈希表(2)哈希函数(3)哈希碰撞 1.2哈希法基本思想1.3哈希法适用场景与最常用的哈希结构 2.LeetCode242:有效的字母异位词(1&#xff09…

《每天一分钟学习C语言·三》

1、 scanf的返回值由后面的参数决定scanf(“%d%d”,& a, &b); 如果a和b都被成功读入,那么scanf的返回值就是2如果只有a被成功读入,返回值为1如果a和b都未被成功读入,返回值为0 如果遇到错误或遇到end of file,返回值为EOF…

另一种理解伦敦金支撑阻力位的方法

支撑阻力位一向被认为是做伦敦金交易不可或缺的分析工具,但很多人对它的原理并不清楚,甚至不太服气,觉得凭什么一根平平无奇的水平位,能带来所谓的“大作用”呢?下面我们不妨从另外一个角度来看一下伦敦金市场中的支撑…

23、Web攻防——Python考点CTF与CMS-SSTI模板注入PYC反编译

文章目录 一、PYC文件二、SSTI 一、PYC文件 pyc文件:python文件编译后生成的字节码文件(byte code),pyc文件经过python解释器最终会生成机器码运行。因此pyc文件是可以跨平台部署的,类似java的.class文件,…

金蝶EAS打印凭证,数据量多点的就会出错

金蝶EAS打印凭证,数据量多点的就会出错,约过100页,提示数据源有问题 经咨询工程师需修改java虚拟机内存。 打开eas客户端目录,运行set-url.bat 看到原来java虚拟机只配置了512M内存,把虚拟机内存修改为4096&#xff0…

如何解决苹果应用商城审核拒绝的Guideline 2.1 - Information Needed问题

当你的应用程序在苹果应用商城审核过程中被拒绝时,苹果会向您发送一封邮件,其中提供了关于拒绝原因的详细信息。本文将指导您如何正确处理Guideline 2.1 - Information Needed问题,并提供解决方案,以确保您的应用程序能够通过审核…

ansible的脚本—playbook剧本

一、playbook 1、简介 Playbook 剧本是由一个或多个play组成的列表。 play的主要功能在于将预定义的一组主机,装扮成事先通过ansible中的task定义好的角色。 Task实际是调用ansible的一个module,将多个play组织在一个playbook中,即可以让它…

系列十一(面试)、如何查看JVM的参数?

一、查看JVM的参数 1.1、概述 上篇文章介绍了JVM的参数类型,通过jinfo可以查看JVM的默认参数,本章介绍另外一种查看JVM参数的方式。 1.2、 分类 JVM中提供了三种方式查看JVM的参数信息,这三种方式又分为两类,即:查看默…

安防监控EasyCVR平台如何通过api接口设置实时流的sei数据实现画框等操作?

国标GB28181视频监控系统EasyCVR平台采用了开放式的网络结构,支持高清视频的接入和传输、分发,能提供实时远程视频监控、视频录像、录像回放与存储、告警、语音对讲、云台控制、平台级联、磁盘阵列存储、视频集中存储、云存储等丰富的视频能力&#xff0…

(PC+WAP)装修设计公司网站模板 家装公司网站源码下载

(PCWAP)装修设计公司网站模板 家装公司网站源码下载 PbootCMS内核开发的网站模板,该模板适用于装修设计、家装公司类等企业,当然其他行业也可以做,只需要把文字图片换成其他行业的即可; PCWAP,同一个后台&#xff0c…

贪吃蛇(一)

ncurses的使用 这是是用于改善用户交互的一个库,做到即时响应。 它的基本使用,涉及到两个函数initscr、endwin,涉及到键盘输入的交互,就需要使用到keypad函数。 基本用法 #include"curses.h" int main() {int key;in…