gpt4 book ai didi

java - Cayenne 缓存 - 查询缓存会取代对象缓存吗?

转载 作者:行者123 更新时间:2023-11-30 07:43:42 25 4
gpt4 key购买 nike

我正在寻找有关如何在集群或使用同一域的多个 JVM 中运行时最佳配置 cayenne 的资源。我一直在阅读文档,我看到了这一点:

“有多种方法可以通知其他堆栈有关对象更改的信息。这可以在 Modeler 中设置。但是,每个更改的完全同步通常会导致过多的网络流量和 CPU 消耗,并且通常会避免有利于查询本章其他地方描述了缓存方法。”

链接到“查询结果缓存”页面。据我了解,当通过 getter 检索关联对象或通过其 id 检索对象时,会使用对象缓存。这句话是否告诉我,如果我配置查询缓存,则不会使用对象缓存?或者我需要避免这样做会影响应用程序代码中的对象缓存?我应该完全禁用对象缓存吗(如果可能的话)?如果我不设置辣椒来通知其他堆栈对象缓存的更改,我是否会面临数据过时的风险?

我很欣赏有关跨多个节点运行辣椒的最佳方式的所有提示,或者如果您有一些资源可以向我指出,那也会非常有帮助。

预先感谢您的宝贵时间!

最佳答案

对象缓存和查询缓存彼此独立,尽管它们可以影响彼此的状态。

对象缓存

扩展对象图时会访问对象缓存(正如您正确注意到的那样)。但是对象缓存的同步不仅仅会更新缓存,还会传播到ObjectContext,从而导致内存中对象图的刷新。虽然这听起来很棒并且 super 自动,但从经验来看,当您拥有与单个用户相关的有限对象图时,它在桌面应用程序中最有用。在集群多用户 Web 应用程序中,同步对象缓存不仅是一种麻烦,而且还有帮助。它会产生大量网络流量,迫使您的实例消耗 CPU 来处理它们并不真正关心的事件,最后,在您最意想不到的时候从底层更新您的对象。所以我通常会关闭对象缓存同步,而纯粹依靠集群查询缓存来处理同步。

查询缓存

这里是an example project演示带有集群的查询缓存。它使用 Cayenne 4.0、EHCache 作为缓存提供程序,并使用 ActiveMQ/JMS 来处理跨实例事件。

查询缓存的工作方式是,它缓存与给定查询匹配的对象列表,包括预取的相关对象(如果查询包含预取)。要充分利用查询缓存,您可能需要稍微改变一下编码风格。您无需在实例变量中存储对查询结果列表的长期引用(本质上是进行自己的缓存),而是在需要此类列表时创建并运行查询(使用适当的缓存设置),并让 Cayenne 决定该列表是否应该从缓存返回或从数据库新鲜获取。

下一步是根据您使用的提供程序指定其默认过期策略(每个缓存组)来配置缓存。例如。一个sample EHCache config .

最后,您可以添加集群和事件驱动的缓存刷新,这可以通过 API 调用显式完成,也可以在提交某些实体时隐式完成(仅自 Cayenne 3.1 起可用)。

查询缓存刷新非常便宜。通过网络发送的唯一内容是“缓存组”的名称,并且在接收端,一堆列表立即被延迟失效。它还会产生更清晰的代码。

如果您主要依赖查询缓存,则无需“关闭”对象缓存本身。对象缓存是 Cayenne 的一个组成部分,许多操作(更新、关系处理)都需要它。当您运行查询时,它将自动更新。不过,您通常需要做的是关闭自动对象刷新。通过不启用对象缓存集群,您已经避免了跨 JVM 同步。此外,您可以使用 this advice禁用同一虚拟机内的跨 ObjectContext 同步。

卡宴版本

我强烈建议至少升级到 Cayenne 3.1(甚至 4.0.M2)。除了其他好处之外,缓存机制比 3.0 更加成熟。它将使您配置 Cayenne 和集成外部缓存提供程序的体验变得更加轻松。

关于java - Cayenne 缓存 - 查询缓存会取代对象缓存吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34244260/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com