ansible之并发运行
来源:互联网 发布:消防三知四会一联通 编辑:程序博客网 时间:2024/06/14 02:01
ansible默认只会创建5个进程,所以一次任务只能同时控制5台机器执行.那如果你有大量的机器需要控制,或者你希望减少进程数,那你可以采取异步执行.ansible的模块可以把task放进后台,然后轮询它.这使得在一定进程数下能让大量需要的机器同时运作起来.
使用async和poll这两个关键字便可以并行运行一个任务. async这个关键字触发ansible并行运作任务,而async的值是ansible等待运行这个任务的最大超时值,而poll就是ansible检查这个任务是否完成的频率时间.
如果你希望在整个集群里面平行的执行一下updatedb这个命令.使用下面的配置
- hosts: all
tasks:
- name: Install mlocate
yum: name=mlocate state=installed
- name: Run updatedb
command: /usr/bin/updatedb
async: 300
poll: 10
你会发现当你使用上面的例子控制超过5台机器的时候,command.在上面yum模块会先在5台机器上跑,完成后再继续下面的机器.而上面command模块的任务会一次性在所有机器上都执行了,然后监听它的回调结果
如果你的command是控制机器开启一个进程放到后台,那就不需要检查这个任务是否完成了.你只需要继续其他的动作,最后再使用wait_for这个模块去检查之前的进程是否按预期中开启了便可.只需要把poll这个值设置为0,便可以按上面的要求配置ansible不等待job的完成.
最后,或者你还有一种需求是有一个task它是需要运行很长的时间,那你需要设置一直等待这个job完成.这个时候你把async的值设成0便可.
总结来说,大概有以下的一些场景你是需要使用到ansible的polling特性的
1、你有一个task需要运行很长的时间,这个task很可能会达到timeout.
2、你有一个任务需要在大量的机器上面运行
3、你有一个任务是不需要等待它完成的
当然也有一些场景是不适合使用polling特性的
1、你的这个任务是需要运行完后才能继续另外的任务的
使用async和poll这两个关键字便可以并行运行一个任务. async这个关键字触发ansible并行运作任务,而async的值是ansible等待运行这个任务的最大超时值,而poll就是ansible检查这个任务是否完成的频率时间.
如果你希望在整个集群里面平行的执行一下updatedb这个命令.使用下面的配置
- hosts: all
tasks:
- name: Install mlocate
yum: name=mlocate state=installed
- name: Run updatedb
command: /usr/bin/updatedb
async: 300
poll: 10
你会发现当你使用上面的例子控制超过5台机器的时候,command.在上面yum模块会先在5台机器上跑,完成后再继续下面的机器.而上面command模块的任务会一次性在所有机器上都执行了,然后监听它的回调结果
如果你的command是控制机器开启一个进程放到后台,那就不需要检查这个任务是否完成了.你只需要继续其他的动作,最后再使用wait_for这个模块去检查之前的进程是否按预期中开启了便可.只需要把poll这个值设置为0,便可以按上面的要求配置ansible不等待job的完成.
最后,或者你还有一种需求是有一个task它是需要运行很长的时间,那你需要设置一直等待这个job完成.这个时候你把async的值设成0便可.
总结来说,大概有以下的一些场景你是需要使用到ansible的polling特性的
1、你有一个task需要运行很长的时间,这个task很可能会达到timeout.
2、你有一个任务需要在大量的机器上面运行
3、你有一个任务是不需要等待它完成的
当然也有一些场景是不适合使用polling特性的
1、你的这个任务是需要运行完后才能继续另外的任务的
2、你的这个任务能很快的完成
转载:http://www.kisops.com/?p=42
阅读全文
0 0
- ansible之并发运行
- ansible之并发运行
- ansible学习之--ansible初探
- 配置运行Ansible
- ansible 配置运行环境
- Ansible(二):Ansible之剧本(Playbooks)
- ansible register 之用法
- LINUX学习之ANSIBLE
- ansible之inventory文件
- ansible之yaml语法
- ansible之patterns
- ansible之playbook入门
- ansible之variable
- ansible之条件语句
- ansible之loops
- ansible学习之--安装Svn
- python之ansible 2.0 API
- Ansible之playbook学习一
- Java线程池的分析和使用
- Linux 基础命令(第二天)
- expdp/impdp导入导出数据
- 【C#】 .NET Reflector 安装与破解
- 0-1背包
- ansible之并发运行
- Tensorflow学习-工具相关
- C#回顾学习笔记十六:out、ref和params参数
- Solr Facet 统计查询
- spring线程池ThreadPoolTaskExecutor
- 小购物车
- JSP页面无法正常翻译问题 ---jsp cannot be resolved to a type
- Java导出Word文档使用iText操作
- goahead-3.3.6源码分析