概述
Caffeine - Caches - Refresh
- 刷新
刷新
LoadingCache<Key, Graph> graphs = Caffeine.newBuilder()
.maximumSize(10_000)
.refreshAfterWrite(1, TimeUnit.MINUTES)
.build(key -> createExpensiveGraph(key));
刷新与剔除并不完全相同。正如LoadingCache.refresh(K)指出的,刷新key会异步加载该key的新值。在key被刷新时,仍然会返回旧值(如果有的话),而剔除则会使检索等待直到新值被加载。
与expireAfterWrite方法相比,refreshAfterWrite将使key在指定的持续时间后符合刷新条件,但仅在条目查询时才真正启动刷新。因此,例如,您可以在同一缓存上同时指定refreshAfterWrite 和 expireAfterWrite,这样当条目符合刷新条件时,过期计时器不会盲目的重置。如果条目符合刷新条件后未对其进行查询,则允许该条目过期。
CacheLoader可以通过重写CacheLoader.reload(K, V)为刷新指定智能行为,该行为允许使用旧值计算新值。
刷新操作是通过Executor异步执行的。默认的执行器是ForkJoinPool.commonPool(),您可以通过Caffeine.executor(Executor)重写执行器。
如果在执行刷新操作时抛出异常,旧值将被保留,异常会记录日志(通过Logger)并吞掉。
最后
以上就是饱满小蘑菇为你收集整理的Caffeine - Caches - Refresh的全部内容,希望文章能够帮你解决Caffeine - Caches - Refresh所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复