AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / computer / 问题 / 1664197
Accepted
rawat
rawat
Asked: 2021-07-23 22:18:07 +0800 CST2021-07-23 22:18:07 +0800 CST 2021-07-23 22:18:07 +0800 CST

Ansible 关键字 - 油门

  • 772

我正在尝试使用和了解节流关键字的工作原理。

下面是我如何使用它(test-playbook.yaml)。

---
- name: Test throttle
  hosts: all
  
  tasks:

    # list of pre tasks
    
    - name: Execute sequentially
      throttle: 1
      block:
        - include_tasks: task-1.yaml
        
        - include_tasks: task-2.yaml
        
        # a task using some module
        
        # a task using some module

    # list of post tasks

执行ansible-playbook --inventory some-inventory --limit host1:host2:host3

我期望在任务(按顺序执行)中,--limit 中指定的所有主机都将按顺序执行,即 host1 将完成块中的所有任务,然后是 host2,然后是 host3

但是它们是并行执行的(默认的 Ansible 行为)。

有人可以帮助理解油门行为吗?我错过了一些配置吗?

forks/serial有默认值。

以及如何实现顺序行为。

ansible
  • 1 1 个回答
  • 1515 Views

1 个回答

  • Voted
  1. Best Answer
    Vladimir Botka
    2021-07-24T01:12:19+08:002021-07-24T01:12:19+08:00

    ansible-playbook的默认行为是线性策略:

    任务执行按串行(默认全部)定义的每个主机批次同步执行。达到分叉限制的主机将同时执行每个任务,然后执行下一系列主机,直到批处理完成,然后再执行下一个任务。

    油门的目的是“限制特定任务的工作人员数量......使用油门来限制可能是 CPU 密集型或与速率限制 API 交互的任务”。

    例如,默认情况下,在所有主机上并行执行任务(受限于串行到forks )

    - hosts: host1,host2,host3
      tasks:
        - command: sleep 1
          register: result
        - debug:
            msg: "{{ inventory_hostname }} task1
                  {{ result.start }} - {{ result.end }}"
    

    可以看到所有主机都并行执行了任务

    ok: [host2] => 
      msg: host2 task1 2021-07-23 08:56:14.735263 - 2021-07-23 08:56:15.759474
    ok: [host1] => 
      msg: host1 task1 2021-07-23 08:56:14.743419 - 2021-07-23 08:56:15.759518
    ok: [host3] => 
      msg: host3 task1 2021-07-23 08:56:14.475249 - 2021-07-23 08:56:15.551159
    

    如果通过油门限制执行

        - command: sleep 1
          register: result
          throttle: 1
        - debug:
            msg: "{{ inventory_hostname }} task2
                  {{ result.start }} - {{ result.end }}"
    

    可以看到任务的执行是序列化的

    ok: [host2] => 
      msg: host2 task2 2021-07-23 08:56:20.252623 - 2021-07-23 08:56:21.312210
    ok: [host3] => 
      msg: host3 task2 2021-07-23 08:56:22.688410 - 2021-07-23 08:56:23.744130
    ok: [host1] => 
      msg: host1 task2 2021-07-23 08:56:17.937011 - 2021-07-23 08:56:18.955631
    

    在开始实验之前,请确保时间已同步。


    问:“使用 include_tasks 我没有得到相同的行为。所有包含的任务都在并行运行。 ”

    答:我无法重现您的问题。鉴于文件

    shell> ansible --version
    ansible 2.10.1
    
    shell> cat test-119-tasks-2.yml
    ---
    - command: sleep 1
      register: result
    - debug:
        msg: "{{ inventory_hostname }} task2
              {{ result.start }} - {{ result.end }}"
    
    shell> cat test-119-tasks-3.yml
    ---
    - command: sleep 1
      register: result
    - debug:
        msg: "{{ inventory_hostname }} task3
              {{ result.start }} - {{ result.end }}"
    

    任务

        - name: Execute sequentially
          throttle: 1
          block:
            - include_tasks: test-119-tasks-2.yml
            - include_tasks: test-119-tasks-3.yml
    

    给

    TASK [include_tasks] ***********************************************
    included: /export/scratch/tmp8/test-119-tasks-2.yml for host1, host2, host3
    TASK [command] *****************************************************
    changed: [host1]
    changed: [host2]
    changed: [host3]
    
    TASK [debug] *******************************************************
    ok: [host1] => 
      msg: host1 task2 2021-07-25 10:56:11.832219 - 2021-07-25 10:56:12.848834
    ok: [host2] => 
      msg: host2 task2 2021-07-25 10:56:14.312498 - 2021-07-25 10:56:15.330202
    ok: [host3] => 
      msg: host3 task2 2021-07-25 10:56:16.751018 - 2021-07-25 10:56:17.774723
    
    TASK [include_tasks] ***********************************************
    included: /export/scratch/tmp8/test-119-tasks-3.yml for host1, host2, host3
    
    TASK [command] ******************************************************
    changed: [host1]
    changed: [host2]
    changed: [host3]
    
    TASK [debug] ********************************************************
    ok: [host1] => 
      msg: host1 task3 2021-07-25 10:56:20.373052 - 2021-07-25 10:56:21.405847
    ok: [host2] => 
      msg: host2 task3 2021-07-25 10:56:22.761254 - 2021-07-25 10:56:23.788941
    ok: [host3] => 
      msg: host3 task3 2021-07-25 10:56:25.134650 - 2021-07-25 10:56:26.151786
    

    可以看到包含的任务的执行是序列化的。这可以按预期工作,因为block中允许使用关键字throttle。将这样的关键字应用于块与将关键字应用于块中的所有任务相同。

    • 2

相关问题

  • 如何在 Ansible 中设置树上的文件权限

  • 在 Visual Studio 代码中编辑 ansible 保险库文件

  • 如何在剧本中混合特权用户和非特权用户?

  • 如何在 group_vars 中使用模板变量

  • 第二次运行 playbook 时 Ansible 挂起

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何减少“vmmem”进程的消耗?

    • 11 个回答
  • Marko Smith

    从 Microsoft Stream 下载视频

    • 4 个回答
  • Marko Smith

    Google Chrome DevTools 无法解析 SourceMap:chrome-extension

    • 6 个回答
  • Marko Smith

    Windows 照片查看器因为内存不足而无法运行?

    • 5 个回答
  • Marko Smith

    支持结束后如何激活 WindowsXP?

    • 6 个回答
  • Marko Smith

    远程桌面间歇性冻结

    • 7 个回答
  • Marko Smith

    子网掩码 /32 是什么意思?

    • 6 个回答
  • Marko Smith

    鼠标指针在 Windows 中按下的箭头键上移动?

    • 1 个回答
  • Marko Smith

    VirtualBox 无法以 VERR_NEM_VM_CREATE_FAILED 启动

    • 8 个回答
  • Marko Smith

    应用程序不会出现在 MacBook 的摄像头和麦克风隐私设置中

    • 5 个回答
  • Martin Hope
    Saaru Lindestøkke 为什么使用 Python 的 tar 库时 tar.xz 文件比 macOS tar 小 15 倍? 2021-03-14 09:37:48 +0800 CST
  • Martin Hope
    CiaranWelsh 如何减少“vmmem”进程的消耗? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Windows 10 搜索未加载,显示空白窗口 2020-02-06 03:28:26 +0800 CST
  • Martin Hope
    v15 为什么通过电缆(同轴电缆)的千兆位/秒 Internet 连接不能像光纤一样提供对称速度? 2020-01-25 08:53:31 +0800 CST
  • Martin Hope
    andre_ss6 远程桌面间歇性冻结 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney 为什么在 URL 后面加一个点会删除登录信息? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension 鼠标指针在 Windows 中按下的箭头键上移动? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    jonsca 我所有的 Firefox 附加组件突然被禁用了,我该如何重新启用它们? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK 是否可以使用文本创建二维码? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 更改 git init 默认分支名称 2019-04-01 06:16:56 +0800 CST

热门标签

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve