1

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

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

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

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

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

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

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

4

1 回答 1

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) behavior to be: If time to reload, return previous entry, reload in background (see specs) there you find关于它的更多细节。

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

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

非常欢迎反馈。

于 2016-03-04T08:22:45.913 回答