java之guava cache应用

google的guava cache是一个轻量级进程内缓存框架。

如何使用guava cache

a. 引入方便,只需要引用google开源java类库即可,guava cache只是其中的一个包。

b. 使用简洁,Guava cache对泛型具有良好的支持,支持多种类型的缓存。例如:String=Object,Integer=Object。

c. 不需要配置文件,直接通过代码配置缓存的各种参数,例如:并发线程量(concurrencyLevel,写的线程数)、容器初始容量(initialCapacity)、缓存移除通知(removalListener)、缓存不命中的加载数据方法(CacheLoader的load)、缓存失效策略(expireAfterWrite、maximumSize(LRU)),当然上述方法中“缓存不命中的加载数据方法”只有特殊的缓存实例支持。

d. 最特殊的:guava cache 是单线程,guava cache不会创建线程来维护缓存。

什么时候使用guava cache

a. 你愿意消耗一些内存空间来提升速度。
b. 你预料到某些键会被查询一次以上。
c. 缓存中存放的数据总量不会超出内存容量。(Guava Cache是单个应用运行时的本地缓存。它不能把数据存放到文件或外部服务器)
d. guava cache可以缓存少量的频繁查询的数据。
e. guava cache的缓存失效,并不是立刻失效,而是延迟失效,原因:guava cache并不会启动线程,而是利用当前线程,进行缓存失效处理,例如会在写操作后调用缓存清理,如果写操作太少会在读操作进行缓存清理。当然如果对缓存清理要求严格,可以自己创建维护线程,进行缓存清理工作,例如:定时任务、其他线程
f. 因为使用的是缓存,所以需要考虑缓存一致性对需求的要求。
g. 因为是进程内缓存,guava cache没有提供缓存的持久化。
h. Guava cache可以根据不同的业务设置不同的cache,可以做到同一业务的同一处理,但是又会引发缓存的离散,这个需要衡量。

guava cache应用案例

@Component
public class AppManager {

    private LoadingCache<Integer, AppVO> apps;
    
    /**
    * 指定的初始化方法
    */
    @PostConstruct
    public void init() {

        apps = CacheBuilder.newBuilder()
                .maximumSize(1000)
                .expireAfterWrite(30, TimeUnit.MINUTES).build(new CacheLoader<Integer, AppVO>() {
                    @Override
                    public AppVO load(Integer appId) throws Exception {
                        String json = getAppConfig(appId);
                        if (json != null) {
                            try {
                                return JSON.parseObject(json, AppVO.class);
                            } catch (Exception e) {
                                log.error("appId:{} return null,json -> {} ", appId, json, e);
                            }
                        }
                        return new AppVO();
                    }
                });
    }
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。