节点查询缓存设置
编辑节点查询缓存设置
编辑用于过滤器上下文的查询结果会被缓存在节点查询缓存中,以便快速查找。每个节点有一个查询缓存,该缓存由所有分片共享。缓存使用 LRU(最近最少使用)驱逐策略:当缓存已满时,最近最少使用的查询结果会被驱逐,以便为新数据腾出空间。您无法检查查询缓存的内容。
Term 查询和在过滤器上下文之外使用的查询不符合缓存条件。
默认情况下,缓存最多保存 10000 个查询,最多占用总堆空间的 10%。为了确定查询是否符合缓存条件,Elasticsearch 维护一个查询历史记录来跟踪出现次数。
如果一个段包含至少 10000 个文档,并且该段至少占分片总文档的 3%,则缓存是按段进行的。由于缓存是按段进行的,因此合并段可能会使缓存的查询失效。
以下设置是静态的,必须在集群中的每个数据节点上进行配置
-
indices.queries.cache.size
- (静态)控制过滤器缓存的内存大小。接受百分比值,例如
5%
,或精确值,例如512mb
。默认为10%
。