guava的loadingCache

使用LoadingCache时,有几点需要注意:

缓存加载策略:LoadingCache提供了两种主要的缓存加载策略:expireAfterWrite和refreshAfterWrite。expireAfterWrite表示在写入缓存后经过一定时间,缓存会自动失效,此时会调用load方法重新加载缓存。然而,在加载期间,所有线程对该缓存key的访问都会被阻塞,因此如果加载过程耗时较长,这种方式可能并不适用。而refreshAfterWrite则需要实现CacheLoader的reload方法,缓存失效后的重新加载是异步的,加载期间尝试获取缓存的线程不会被阻塞,而是会获取到加载之前的值。只有当加载完成后,各线程才能获取到最新值。
并发控制:在多个线程同时尝试获取一个不存在的key时,LoadingCache会确保只有一个线程负责加载,而其他线程会阻塞等待。这样可以避免多个线程重复加载相同的数据,提高了效率和数据的准确性。
缓存大小与回收:使用CacheBuilder创建LoadingCache时,可以设置缓存的最大大小(maximumSize)。当缓存接近或达到上限时,会根据一定的策略(如LRU,最近最少使用)来释放长时间未被访问的对象。同时,还可以设置基于访问时间或写入时间的缓存过期策略(expireAfterAccess或expireAfterWrite),以便自动删除长时间未被访问或写入的对象。
远程缓存的考虑:在使用远程集中式缓存时,需要考虑远程调用的开销以及缓存对象的序列化和反序列化开销。为了优化性能,应合理设置缓存对象的大小,并尽量避免在获取一个完整对象时多次访问缓存信息。此外,还需要考虑缓存服务器的单点问题,如宕机时所有对缓存的访问都会失效,因此应有备份的缓存服务器策略。

综上所述,使用LoadingCache时,需要关注缓存加载策略、并发控制、缓存大小与回收以及远程缓存的考虑等因素,以确保缓存的效率和数据的准确性。

refreshAfterWrite到期后并不会自动触发刷新操作。refreshAfterWrite参数在Guava的LoadingCache中是用来设定缓存项自上次更新操作之后多久会被刷新。然而,这个刷新操作并不会在过期时间到达时自动执行。

实际上,只有当有线程调用get(key)方法去获取这个key的值时,如果当前时间距离上一次更新操作的时间已经超过了refreshAfterWrite设定的值,那么LoadingCache才会在后台异步地执行刷新操作。也就是说,如果没有线程去主动获取这个key的值,那么即使refreshAfterWrite的过期时间到了,缓存项也不会被刷新。

因此,在使用refreshAfterWrite时,需要注意这一点,确保有线程在合适的时候去调用get(key)方法,以触发缓存项的刷新。同时,由于刷新操作是异步的,所以在刷新过程中,如果有线程尝试获取这个key的值,它们将获取到刷新操作之前的旧值,直到刷新操作完成,新值才会被返回。

综上所述,refreshAfterWrite并不会自动刷新缓存项,而是需要线程在合适的时候去调用get(key)方法以触发刷新操作。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • com.google.common.cache 1、背景 缓存,在我们日常开发中是必不可少的一种解决性能问题的方法...
    拾壹北阅读 22,536评论 0 25
  • 使用场景 缓存在很多场景下都是相当有用的。例如,计算或检索一个值的代价很高,并且对同样的输入需要不止一次获取值的时...
    jiangmo阅读 834评论 0 3
  • 缓存在应用中是必不可少的,经常用的如redis、memcache以及内存缓存等。Guava是Google出的一个工...
    timothyue1阅读 1,643评论 1 1
  • 缓存的使用可以大大提高程序的执行效率,但是如果缓存无法及时更新会导致脏读的情况。 痛点剖析: 记得早期我呆过的一家...
    hello_coke阅读 45,533评论 4 31
  • 原文链接:原文链接 注:这篇文章是我自己根据官方文档的原文翻译的,因为能力有限,有些地方翻译的不好,欢迎批评指正,...
    大风过岗阅读 27,195评论 0 16