Guava cache - JiyangM/spring GitHub Wiki

Guava Cache适用场景

1、你愿意消耗一部分内存来提升速度;

2、你已经预料某些值会被多次调用;

3、缓存数据不会超过内存总量;

特点

  • 线程安全


加载 cache 的两种方式

  1. cacheLoader

  2. callable callback

从缓存中取key X的值,如果该值已经缓存过了,则返回缓存中的值,如果没有缓存过,可以通过某个方法来获取这个值


guava Cache数据移除:

  guava做cache时候数据的移除方式,在guava中数据的移除分为被动移除和主动移除两种。   被动移除数据的方式,guava默认提供了三种方式:   1.基于大小的移除:看字面意思就知道就是按照缓存的大小来移除,如果即将到达指定的大小,那就会把不常用的键值对从cache中移除。   定义的方式一般为 CacheBuilder.maximumSize(long),还有一种一种可以算权重的方法,个人认为实际使用中不太用到。就这个常用的来看有几个注意点,     其一,这个size指的是cache中的条目数,不是内存大小或是其他;     其二,并不是完全到了指定的size系统才开始移除不常用的数据的,而是接近这个size的时候系统就会开始做移除的动作;     其三,如果一个键值对已经从缓存中被移除了,你再次请求访问的时候,如果cachebuild是使用cacheloader方式的,那依然还是会从cacheloader中再取一次值,如果这样还没有,就会抛出异常   2.基于时间的移除:guava提供了两个基于时间移除的方法     expireAfterAccess(long, TimeUnit) 这个方法是根据某个键值对最后一次访问之后多少时间后移除     expireAfterWrite(long, TimeUnit) 这个方法是根据某个键值对被创建或值被替换后多少时间移除   3.基于引用的移除:   这种移除方式主要是基于java的垃圾回收机制,根据键或者值的引用关系决定移除   主动移除数据方式,主动移除有三种方法:   1.单独移除用 Cache.invalidate(key)   2.批量移除用 Cache.invalidateAll(keys)   3.移除所有用 Cache.invalidateAll()   如果需要在移除数据的时候有所动作还可以定义Removal Listener,但是有点需要注意的是默认Removal Listener中的行为是和移除动作同步执行的,如果需要改成异步形式,可以考虑使用RemovalListeners.asynchronous(RemovalListener, Executor)