【问题标题】:Is there any third party java cache which provides control over the expiration event?是否有任何第三方 java 缓存可以控制过期事件?
【发布时间】:2016-06-17 20:01:39
【问题描述】:

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

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

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

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

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

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

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

【问题讨论】:

  • 听起来您不想过期,但refreshAfterWrite 因为您不想删除条目(仅更新其值)。
  • refreshAfterWrite 是在给定的持续时间之后只更新一个条目还是整个缓存?如果刷新时抛出任何异常,那么之前的条目会保持原样还是会抛出异常?我检查了一下,它需要异步覆盖 reload() 方法。你能解释一下为什么异步吗?
  • 它是每个条目,在重新加载时返回先前的值,并在第一个调用者的线程上执行,或者可以完全异步。如果您想要完整的定期刷新,最简单的方法是使用ScheduledExecutorService

标签: java caching ehcache google-guava-cache


【解决方案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

非常欢迎反馈。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2017-02-20
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-09-28
    • 2013-02-10
    • 2023-03-25
    • 2011-12-02
    相关资源
    最近更新 更多