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



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

如果条目即将过期,则应进行服务查找以获取最新条目。 让我们调用是服务刷新。

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

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

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

我正在研究谷歌番石榴缓存,但它只提供了一个 removalListener,它只会通知我事件,但我无法用它控制过期事件。

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

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

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

使用exceptionExpiryDuration您实际上可以为重试设置更短的间隔。SO上有一个类似的问题,我也回答了,请参阅: 是否可以将番石榴缓存(或其他库)行为配置为: 如果需要重新加载,则返回上一个条目,在后台重新加载(请参阅规格) 在那里,您可以找到有关它的更多详细信息。

无论您使用哪种缓存,都会遇到很多问题,因为一般情况下的异常处理以及构建健壮且有弹性的应用程序需要对细节进行一些思考。

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

非常欢迎反馈。

最新更新