Guava的两种缓存策略
缓存在很多场景下都需要使用,如果电商网站的商品类别的查询,订单查询,用户基本信息的查询等等,针对这种读多写少的业务,都可以考虑使用到缓存。在一般的缓存系统中,除了分布式缓存,还会有多级缓存,在提升一定性能的前提下,可以在一定程度上避免缓存击穿或缓存雪崩,也能降低分布式缓存的负载。
GuavaCache的优点
1)很好的封装了get、put操作,能够集成数据源。一般我们在业务中操作缓存都会操作缓存和数据源两部分。例如:put数据时,先插入DB再删除原来的缓存,get数据时,先查缓存,命中则返回,没有命中时需要查询DB,再把查询结果放入缓存中。Guava封装了这么多步骤,只需要调用一次get/put方法即可
2)它是线程安全的缓存,与ConcurrentMap相似,但前者增加了更多的元素失效策略,后者只能显示的移除元素
3)GuavaCache提供了三种基本的缓存回收方式:基于容量回收、定时回收和基于引用回收。定时回收有两种:按照写入时间,最早写入的最先回收;按照访问时间,最早访问的最早回收
4)它可以监控加载/命中情况
Cache类型本地缓存
package com.mine.localcache.guava;
import com.google.common.cache.Cache;
import com.google.common.cache.CacheBuilder;
import java.util.Map;
import java.util.concurrent.Callable;
import java.util.concurrent.TimeUnit;
/**
* ******************************
* author: 柯贤铭
* createTime: 2019/7/30 14:21
* description: Guava 本地缓存 -> Cache类型
* 用于SpringBoot项目中,启用单例模式 项目启动时进行初始化
* pay attention -> A. 注意不要重复实例化, 最好交由IOC管理
* B. 注意如果是写操作则获取缓存值后拷贝一份副本,然后传递该副本,进行修改操作
* C. 支持自定义call回调
* version: V1.0
* ******************************
*/
public class CacheUtil {
/***
* 构造方法 - 进行初始化
* @param maxSize 最大容量
* @param invalidTime 刷新时间 | 基于分钟级别
*/
public CacheUtil(long maxSize, long invalidTime) {
init(maxSize, invalidTime);
}
/***
* 初始化
*/
private void init (long maxSize, long invalidTime) {
// 缓存
cache = CacheBuilder.newBuilder()
// 设置缓存在写入invalidTime分钟后失效
.expireAfterWrite(invalidTime, TimeUnit.MINUTES)
// 设置缓存个数
.maximumSize