我有一个不断扩展的剧本,把几百台机器修补到最新的版本中,我只是在不同的参数中添加了相同的角色。
显然,游戏手册在每台机器上运行的时间越来越长,尽管它并没有对它们做任何事情。
我所做的是在预任务中,我得到一个changelog文件,检查它,并在成功运行的标识符不存在时运行每个角色。但是,即便如此,ansible仍然需要相当繁重的时间才能不做任何事情。
当我仔细分析主进程时,它看起来像是试图点击一堆不存在的缓存事实、文件和目录脚本。
我认为我正确地创建了动态清单,它同时接受“
我有大约100个设备,我没有在库存文件中收集事实,我有:
fact_caching_connection = /tmp/factscache
fact_caching = jsonfile准备好了。
如果我把它取出来,它不会试图查找丢失的事实文件,但是它会一次又一次地在库存生成器文件的字符串中找到一个stat。我知道这不可能产生整个库存,因为那需要5秒。
我尝试生成常规库存文件,并使用这些文件,我尝试使用_meta和普通host_vars生成库存文件(目前使用_meta存放主机vars,因为我听说这样做更快)。
(运行ansible 2.0)
发布于 2017-08-14 09:33:57
与其集中存储Ansible代码,还可以提取代码并将其分发到每个项目。这种方法的另一个好处是,配置和代码将一起看到,开发人员将更改配置,并且Ops可以修复例如bug,而不是在筒仓中工作。运行每个项目的代码将防止执行将花费更长、更长的时间。
发布于 2017-08-14 16:32:15
您可以隔离角色并只运行它们,您可以在运行特定角色之前生成一个静态库存列表(以及它的相关任务)。
确保任务不包含大量继承/依赖角色。正如030所提到的,实现某种方式在语义上分离角色可能是个好主意。
https://devops.stackexchange.com/questions/953
复制相似问题