我的用例是我需要在服务之上实现一个缓存,这应该在一段时间后(从创建时起)到期条目。
如果条目过期,则应该进行服务查找以获取最新条目。让呼叫是服务更新。
但是,假设服务刷新失败,那么我应该能够使用缓存中的陈旧数据。
但由于缓存已经过期,我没有该条目。
所以,我正在考虑控制缓存的过期,只有当服务可用于获取最新数据时,缓存条目才会过期,否则不会删除该条目。
我正在调查Google Guava缓存,但它只提供了一个removeListener,它只会通知我事件,但我无法用此控制到期事件。
是否有可以满足我目的的第三方缓存实施?
答案 0 :(得分:1)
这种弹性和健壮性语义在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
非常欢迎反馈。