gpt4 book ai didi

java - 是否有任何第三方java缓存可以提供对过期事件的控制?

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

我的用例是,我需要在服务之上实现缓存,条目应该在一定时间(从创建时间开始)后过期。

如果条目即将过期,则应进行服务查找以获取最新条目。让我们打电话来更新服务。

但是,假设如果服务刷新失败,那么我应该能够使用缓存中的陈旧数据。

但是由于缓存已经过期,我没有该条目。

因此,我正在考虑控制缓存的过期时间,只有当服务可用于获取最新数据时,缓存条目才会过期,否则不要删除该条目。

我正在研究Google Guava缓存,但它只提供了一个removeListener,它只会通知我事件,但我无法用它来控制过期事件。

是否有任何第三方缓存实现可以满足我的目的?

最佳答案

这种弹性和鲁棒性语义在cache2k中实现。 。我们在生产中使用它已经有一段时间了。设置看起来像

CacheBuilder.newCache(Key.class, Value.class)
.name("myCache")
.source(new YourSourceImplementation())
.backgroundRefresh(true)
.suppressExceptions(true)
.expiryDuration(60, TimeUnit.SECONDS)
.build();

使用exceptionExpiryDuration,您实际上可以设置更短的重试间隔。 SO上有一个类似的问题,我也回答了,参见:Is it possible to configure Guava Cache (or other library) behaviour to be: If time to reload, return previous entry, reload in background (see specs)您可以在那里找到更多有关它的详细信息。

无论您使用什么缓存,您都会遇到很多问题,因为一般的异常处理和构建健壮且有弹性的应用程序需要在细节上进行一些思考。

也就是说,我对这个解决方案还不是完全满意,因为我认为我们需要更多的控制,例如陈旧数据应提供多长时间。此外,如果缓存中有陈旧数据,则需要发出一些警报。我在这里提出了一些关于如何改进这一点的想法:https://github.com/cache2k/cache2k/issues/26

非常欢迎提供反馈。

关于java - 是否有任何第三方java缓存可以提供对过期事件的控制?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35790057/

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