首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用动态库存和缓存的facts文件运行Ansible no-op更快

使用动态库存和缓存的facts文件运行Ansible no-op更快
EN

DevOps用户
提问于 2017-04-19 14:54:18
回答 2查看 571关注 0票数 5

我有一个不断扩展的剧本,把几百台机器修补到最新的版本中,我只是在不同的参数中添加了相同的角色。

显然,游戏手册在每台机器上运行的时间越来越长,尽管它并没有对它们做任何事情。

我所做的是在预任务中,我得到一个changelog文件,检查它,并在成功运行的标识符不存在时运行每个角色。但是,即便如此,ansible仍然需要相当繁重的时间才能不做任何事情。

当我仔细分析主进程时,它看起来像是试图点击一堆不存在的缓存事实、文件和目录脚本。

我认为我正确地创建了动态清单,它同时接受“

我有大约100个设备,我没有在库存文件中收集事实,我有:

代码语言:javascript
复制
fact_caching_connection = /tmp/factscache
fact_caching = jsonfile

准备好了。

如果我把它取出来,它不会试图查找丢失的事实文件,但是它会一次又一次地在库存生成器文件的字符串中找到一个stat。我知道这不可能产生整个库存,因为那需要5秒。

我尝试生成常规库存文件,并使用这些文件,我尝试使用_meta和普通host_vars生成库存文件(目前使用_meta存放主机vars,因为我听说这样做更快)。

(运行ansible 2.0)

EN

回答 2

DevOps用户

发布于 2017-08-14 09:33:57

与其集中存储Ansible代码,还可以提取代码并将其分发到每个项目。这种方法的另一个好处是,配置和代码将一起看到,开发人员将更改配置,并且Ops可以修复例如bug,而不是在筒仓中工作。运行每个项目的代码将防止执行将花费更长、更长的时间。

票数 2
EN

DevOps用户

发布于 2017-08-14 16:32:15

您可以隔离角色并只运行它们,您可以在运行特定角色之前生成一个静态库存列表(以及它的相关任务)。

确保任务不包含大量继承/依赖角色。正如030所提到的,实现某种方式在语义上分离角色可能是个好主意。

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

https://devops.stackexchange.com/questions/953

复制
相关文章

相似问题

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