节点查询缓存设置

编辑

用于过滤器上下文的查询结果会被缓存在节点查询缓存中,以便快速查找。每个节点有一个查询缓存,该缓存由所有分片共享。缓存使用 LRU(最近最少使用)驱逐策略:当缓存已满时,最近最少使用的查询结果会被驱逐,以便为新数据腾出空间。您无法检查查询缓存的内容。

Term 查询和在过滤器上下文之外使用的查询不符合缓存条件。

默认情况下,缓存最多保存 10000 个查询,最多占用总堆空间的 10%。为了确定查询是否符合缓存条件,Elasticsearch 维护一个查询历史记录来跟踪出现次数。

如果一个段包含至少 10000 个文档,并且该段至少占分片总文档的 3%,则缓存是按段进行的。由于缓存是按段进行的,因此合并段可能会使缓存的查询失效。

以下设置是静态的,必须在集群中的每个数据节点上进行配置

indices.queries.cache.size
静态)控制过滤器缓存的内存大小。接受百分比值,例如 5%,或精确值,例如 512mb。默认为 10%

查询缓存索引设置

编辑

以下设置是索引设置,可以在每个索引的基础上进行配置。只能在索引创建时或在关闭的索引上设置

index.queries.cache.enabled
静态)控制是否启用查询缓存。接受 true(默认)或 false