首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >并行运行不同的任务Ansible 2.2.0

并行运行不同的任务Ansible 2.2.0
EN

Stack Overflow用户
提问于 2017-01-04 20:14:54
回答 2查看 741关注 0票数 1

我想知道是否有可能在ansible 2.2.0中为两个不同的主机并行部署6个不同的任务(3|3),因为我的问题是将它们与一个攻略并行运行,它们只是顺序运行。

EN

回答 2

Stack Overflow用户

发布于 2017-01-05 18:41:54

您可以使用async任务来实现这一点。如下所示:

代码语言:javascript
复制
- hosts: host1,host2
  tasks:
    - command: /task1a.sh
      async: 1000
      poll: 0
      register: task1a
      when: inventory_hostname == 'host1'
    - command: /task1b.sh
      async: 1000
      poll: 0
      register: task1b
      when: inventory_hostname == 'host2'
    # ... repeat for tasks 2 and 3
    - command: /check_done.sh
      register: check_done
      until: check_done | success
      retries: 30

这将分别在host1和host2上启动task1a.sh和task1b.sh作为异步作业,然后等待check_done.sh返回零。

票数 0
EN

Stack Overflow用户

发布于 2017-01-08 04:58:37

您可以将strategy: freewhen: inventory_hostname == 'hostXX'结合使用,例如:

代码语言:javascript
复制
- hosts: all
  strategy: free
  tasks:
    - block:
        - name: task1
          ...
        - name: task2
          ...
        - name: task3
          ...
      when: inventory_hostname == 'host1'

    - block:
        - name: task4
          ...
        - name: task5
          ...
        - name: task6
          ...
      when: inventory_hostname == 'host2'

strategy: free意味着所有任务将尽可能快地在所有主机上并行运行,而不是等待每个任务在每个主机上完成。哪项任务将在哪台主机上运行由when子句决定。

我在这里使用了block,因此您只需要为每个块编写一个when,但您不必使用它,您可以为每个任务编写一个when

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41463593

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档