5.5#Anisble中的任务执行控制

2023-10-23 16:49
文章标签 控制 执行 任务 5.5 anisble

本文主要是介绍5.5#Anisble中的任务执行控制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实验环境:

在这里插入图片描述在这里插入图片描述

1.循环

循环迭代任务

1.1 简单循环
loop:		##赋值列表- value1- value2- ...{{item}}	##迭代变量名称

在这里插入图片描述

实例

运行useradd.yml,依次建立三个用户westos1、westos2、westos3,密码分别为123、456、789

1.2 循环散列或字典列表
---
- name: create filehosts: 172.25.0.254tasks:- name: file moduleservice:name: "{{ item.name}}"state: "{{ item.state }}"loop:- name: httpdstate: started- name: vsftpdstate: stopped
实验:

运行useradd.yml,依次建立三个用户westos1、westos2、westos3,密码分别为123、456、789

在这里插入图片描述

2.条件
when:- 条件1- 条件2
2.1 条件判断
==			value == "字符串",value == 数字
<			value <  数字
>			value >  数字
<=			value <= 数字
>=			value >= 数字 
!=			value != 数字
is defined value	value is defined		变量存在
is not defined		value is not defined	变量不存在
in                  value is in value       变量为    
not in              value is not in value   变量不为
bool变量 为true		value	  value的值为true
bool变量 false		not value value的值为falsevalue in value2	    value的值在value2列表中
实验1:

判断文件是否存在

在这里插入图片描述
在这里插入图片描述

实验2:

检测硬盘是否存在

准备工作:
在这里插入图片描述脚本:
在这里插入图片描述
过程:
在这里插入图片描述
检测:
在这里插入图片描述

实验3:

in

在这里插入图片描述

2.2 多条条件组合

条件1 and 条件2

when:- 条件1- 条件2

条件1 or 条件2

when: >条件1or条件2

实验3:

建立playbook ~/ansibles/lvm.yml要求如下:
*建立大小为1500M名为exam_lvm的lvm 在westos组中
*如果westos不存在请输出:
vg westos is not exist
*如果westos大小不足1500M请输出:
vg westos is less then 1500M
并建立800M大小的lvm

在这里插入图片描述在这里插入图片描述

在这里插入图片描述

3.触发器

notify:触发器当遇到更改时触发handlers

handlers: 触发器触发后执行的动作

实验:
下载软件httpd,然后启动服务,火墙添加服务,如果软件已经下载,不执行启动服务和火墙
在这里插入图片描述
服务第一次安装:
在这里插入图片描述服务已经安装之后:不启动
在这里插入图片描述

4.处理失败任务
4.1 ignore_errors

作用:
当play遇到任务失败是会终止
ignore_errors: yes 将会忽略任务失败使下面的任务继续运行

实例
- name: testdnf:name: westosstate: latestignore_errors: yes- name: create filefile:path: /mnt/westosstate: touch
4.2.force_handlers

作用:
#当任务失败后play被终止也会调用触发器进程
#example

---
- name: apache change porthosts: 172.25.0.254force_handlers: yesvars:http_port: 80tasks:- name: configure apache conf filelineinfile:path: /etc/httpd/conf/httpd.confregexp: "^Listen"line: "Listen {{ http_port }}"notify: restart apache- name: install errordnf:name: westosstate: latesthandlers:- name: restart apacheservice:name: httpdstate: restartedenabled: yes
4.3.changed_when

作用:
控制任务在任何时候都更改changed (true/false)


  • name: apache change port
    hosts: 172.25.0.254
    force_handlers: yes
    vars:
    http_port: 8080
    tasks:

    • name: configure apache conf file
      lineinfile:
      path: /etc/httpd/conf/httpd.conf
      regexp: “^Listen”
      line: “Listen {{ http_port }}”
      changed_when: true
      notify: restart apache

    handlers:

    • name: restart apache
      service:
      name: httpd
      state: restarted
      enabled: yes
4.4.failed_when

不管命令执行成功失败,都指定输出信息(true/false)

---
- name: testhosts: 172.25.0.254tasks:- name: shellshell: echo helloregister: westosfailed_when: "'hello' in westos.stdout"
4.5.block/rescue/always
block: 		##定义要运行的任务
rescue:		##定义当block句子中出现失败任务后运行的任务
always:	##定义最终独立运行的任务

在这里插入图片描述

#测试练习#
建立playbook ~/westos.yml要求如下:
建立大小为1500M名为/dev/vdb1的设备
如果/dev/vdb不存在请输入:
/dev/vdb is not exist
如果/dev/vdb大小不足2G请输出:
/dev/vdb is less then 2G
并建立800M大小的/dev/vdb1
此设备挂载到/westos上
在这里插入图片描述在这里插入图片描述

这篇关于5.5#Anisble中的任务执行控制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/269140

相关文章

SpringQuartz定时任务核心组件JobDetail与Trigger配置

《SpringQuartz定时任务核心组件JobDetail与Trigger配置》Spring框架与Quartz调度器的集成提供了强大而灵活的定时任务解决方案,本文主要介绍了SpringQuartz定... 目录引言一、Spring Quartz基础架构1.1 核心组件概述1.2 Spring集成优势二、J

Redis实现延迟任务的三种方法详解

《Redis实现延迟任务的三种方法详解》延迟任务(DelayedTask)是指在未来的某个时间点,执行相应的任务,本文为大家整理了三种常见的实现方法,感兴趣的小伙伴可以参考一下... 目录1.前言2.Redis如何实现延迟任务3.代码实现3.1. 过期键通知事件实现3.2. 使用ZSet实现延迟任务3.3

Linux中的计划任务(crontab)使用方式

《Linux中的计划任务(crontab)使用方式》:本文主要介绍Linux中的计划任务(crontab)使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言1、linux的起源与发展2、什么是计划任务(crontab)二、crontab基础1、cro

用js控制视频播放进度基本示例代码

《用js控制视频播放进度基本示例代码》写前端的时候,很多的时候是需要支持要网页视频播放的功能,下面这篇文章主要给大家介绍了关于用js控制视频播放进度的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言html部分:JavaScript部分:注意:总结前言在javascript中控制视频播放

Spring定时任务只执行一次的原因分析与解决方案

《Spring定时任务只执行一次的原因分析与解决方案》在使用Spring的@Scheduled定时任务时,你是否遇到过任务只执行一次,后续不再触发的情况?这种情况可能由多种原因导致,如未启用调度、线程... 目录1. 问题背景2. Spring定时任务的基本用法3. 为什么定时任务只执行一次?3.1 未启用

如何使用Python实现一个简单的window任务管理器

《如何使用Python实现一个简单的window任务管理器》这篇文章主要为大家详细介绍了如何使用Python实现一个简单的window任务管理器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 任务管理器效果图完整代码import tkinter as tkfrom tkinter i

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

使用DrissionPage控制360浏览器的完美解决方案

《使用DrissionPage控制360浏览器的完美解决方案》在网页自动化领域,经常遇到需要保持登录状态、保留Cookie等场景,今天要分享的方案可以完美解决这个问题:使用DrissionPage直接... 目录完整代码引言为什么要使用已有用户数据?核心代码实现1. 导入必要模块2. 关键配置(重点!)3.

Spring Boot 集成 Quartz 使用Cron 表达式实现定时任务

《SpringBoot集成Quartz使用Cron表达式实现定时任务》本文介绍了如何在SpringBoot项目中集成Quartz并使用Cron表达式进行任务调度,通过添加Quartz依赖、创... 目录前言1. 添加 Quartz 依赖2. 创建 Quartz 任务3. 配置 Quartz 任务调度4. 启

Java使用多线程处理未知任务数的方案介绍

《Java使用多线程处理未知任务数的方案介绍》这篇文章主要为大家详细介绍了Java如何使用多线程实现处理未知任务数,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 知道任务个数,你可以定义好线程数规则,生成线程数去跑代码说明:1.虚拟线程池:使用 Executors.newVir