您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

谷歌番石榴缓存invalidateAll()和cleanUp()之间的区别

谷歌番石榴缓存invalidateAll()和cleanUp()之间的区别

Guava如何使CacheBuilder中的条目到期?

我将重点讨论 ,但是 的过程几乎相同。从机制 ,当您在CacheBuilder中指定 时,缓存的每个段都会维护一个条目的链接列表访问队列,其顺序为从最近访问到最新访问。缓存条目实际上本身就是链接列表中的节点,因此,在访问条目时,它会将其从访问队列中的旧位置删除,然后移至队列的末尾。

:通过此链接:Guava CacheLoader-如果同时设置了expireAfterWrite和expireAfterAccess,则invalidate不会立即使条目无效

invalidate 应该立即删除该条目-不等待其他查询-并且应强制在该键的下一个查询中重新加载该值。

cleanUp:执行缓存所需的所有暂挂维护操作。确切地执行哪些活动(如果有)取决于实现。

从 :https ://github.com/google/guava/wiki/CachesExplained

在任何时候,您都可以显式使缓存条目无效,而不必等待条目被逐出。可以这样做:

individually, using Cache.invalidate(key)
in bulk, using Cache.invalidateAll(keys)
to all entries, using Cache.invalidateAll()

使用CacheBuilder构建的缓存不会“自动”执行清理和逐出值,也不会在值过期后立即执行清理或逐出值,或类似的任何操作。取而代之的是,如果写操作很少,它会在写操作期间或偶尔的读操作期间执行少量维护。

原因如下:如果我们要连续执行Cache维护,则需要创建一个线程,并且该线程的操作将与用户操作争夺共享锁。此外,某些环境限制了线程的创建,这会使CacheBuilder在该环境中无法使用。

相反,我们会将选择权交给您。如果您的缓存是高吞吐量的,那么您不必担心执行缓存维护以清理过期的条目等。如果您的缓存确实很少写入,并且您不想清理来阻止缓存读取,则您可能希望创建自己的维护线程,该线程定期调用Cache.cleanUp()。

如果要为很少有写入的缓存安排定期的缓存维护,只需使用scheduledexecutorservice安排维护。

其他 2022/1/1 18:16:24 有463人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶