druid-docs-cn/Querying/querycached.md

4.4 KiB
Raw Blame History

查询缓存

Apache Druid支持两种级别的结果缓存分别是段缓存和整个查询结果的缓存。缓存数据既可以存储在本地JVM堆内存中也可以存储在一个外部的分布式kv存储中。在所有场景中Druid的缓存是查询结果的缓存唯一的差别是特定段的部分结果还是全部结果。 在所有情况下只要数据发生变化缓存即失效Druid永远不会返回过期的结果。

段级缓存中即使某些底层段是可变的并且正在进行实时摄取也允许使用缓存。在这种情况下Druid可能会缓存不可变历史段的查询结果同时重新计算每个查询的实时段的结果。在这种情况下连续的缓存是没有用的因为它的结果是无效的。

段级缓存需要Druid在每次查询时合并每个段的结果即使每个数据段的缓存结果都是从Druid缓存读取时。因此如果不存在由于实时摄取而导致的失效的问题则整个查询结果级缓存可以更高效。

使用和填充缓存

所有缓存都有一对参数,用于控制单个查询如何与缓存交互的行为,"use"缓存参数和"populate"缓存参数。必须通过运行时属性(runtime properties)在服务级别启用这些设置以利用缓存,但可以通过在查询上下文(query context)中设置它们来控制每个查询。"use"参数显然控制查询是否将使用缓存结果, "populate"参数控制查询是否更新缓存的结果。这些是单独的参数,目的是使得不常见数据(例如大型报表或非常旧的数据)的查询不会污染被其他查询重用的缓存结果。

Brokers上边查询缓存

Broker同时支持段级缓存与全部查询结果级缓存。 段级缓存通过参数useCachepopulateCache来控制。全部结果级缓存通过参数useResultLevelCachepopulateResultLevelCache来控制,这些参数都在运行时属性(runtime properties)中的 druid.broker.cache.*

对于小集群在Broker上启用段级缓存比在Historical上启用查询缓存的结果更快。对于较小的生产集群<5台服务器建议使用此设置。对于大型生产集群不建议在Broker上填充段级缓存因为当属性druid.broker.cache.populateCache设置为true(并且查询上下文参数populateCache未设置为false则将会按段返回Historical的结果Historical将无法进行任何本地结果合并。这会削弱Druid集群的扩展能力。

Historical上边查询缓存

Historical仅仅支持段级缓存。段级缓存通过上下文参数useCachepopulateCache以及运行时属性(runtime properties)中的 druid.historical.cache.*来控制。

大型集群应该仅仅在Historical上非Broker启用段级缓存填充这可以避免在Broker上合并所有的查询结果。在Historical上而非Broker上启用缓存填充使得Historical可以在自己本地进行结果合并然后将较少的数据传递给Broker。

摄取任务上的查询缓存

任务执行进程如Peon进程或者实验性的Indexer进程仅仅支持段级缓存。段级缓存通过上下文参数useCachepopulateCache以及运行时属性(runtime properties)中的 druid.realtime.cache.*来控制。

大型集群应该仅仅在任务执行进程上非Broker启用段级缓存填充这可以避免在Broker上合并所有的查询结果。在任务执行进程上而非Broker上启用缓存填充使得任务执行进程可以在自己本地进行结果合并然后将较少的数据传递给Broker。

注意:任务执行进程仅仅支持将段缓存在本地,例如 caffeine缓存。 存在此限制是因为这些缓存是在摄取任务生成的中间部分段级别存储结果,这些中间部分段在任务副本中不一定相同,因此任务执行进程将忽略memcached等远程缓存类型。