使用spring cacheManager配置Guava Cache和Redis Cache

时间:2022-01-06 15:57:00
简单两步,利用spring的cacheManager配置Guava Cache,同时还可以配置以redis实现的cache。使用时通过配置*切换不同的cache实现。
1、创建配置类:
/**
* Cache配置類,用于缓存方法返回的数据
* @author XuJijun
*
*/
@Configuration
@EnableCaching
public class CacheConfig {

public static final int DEFAULT_MAXSIZE = 50000;
public static final int DEFAULT_TTL = 10;

/**
* 定義cache名稱、超時時長(秒)、最大size
* 每个cache缺省10秒超时、最多缓存50000条数据,需要修改可以在构造方法的参数中指定。
*/
public enum Caches{
messageContent(8640000),
getSomeData,
qiniuUpToken(1800, 1),

getCommonAds(60),
getAndAssembleAreaSpecificAds(60);

Caches() {
}

Caches(int ttl) {
this.ttl = ttl;
}

Caches(int ttl, int maxSize) {
this.ttl = ttl;
this.maxSize = maxSize;
}

private int maxSize=DEFAULT_MAXSIZE; //最大數量
private int ttl=DEFAULT_TTL; //过期时间(秒)

public int getMaxSize() {
return maxSize;
}
public void setMaxSize(int maxSize) {
this.maxSize = maxSize;
}
public int getTtl() {
return ttl;
}
public void setTtl(int ttl) {
this.ttl = ttl;
}
}

/**
* 创建基于guava的Cache Manager
* @return
*/
@Bean
@Primary
public CacheManager guavaCacheManager() {
SimpleCacheManager cacheManager = new SimpleCacheManager();

//把各个cache注册到cacheManager中,GuavaCache实现了org.springframework.cache.Cache接口
ArrayList<GuavaCache> caches = new ArrayList<GuavaCache>();
for(Caches c : Caches.values()){
caches.add(new GuavaCache(c.name(), CacheBuilder.newBuilder().recordStats().expireAfterWrite(c.getTtl(), TimeUnit.SECONDS).maximumSize(c.getMaxSize()).build()));
}
cacheManager.setCaches(caches);
return cacheManager;
}

@Autowired
private JedisCluster jedisCluster;

/**
* 创建基于redis的Cache Manager
* @return
*/
@Bean
public CacheManager redisCacheManager() {
JedisClusterCacheManager cacheManager = new JedisClusterCacheManager(jedisCluster);

ArrayList<JedisClusterCache> caches = new ArrayList<JedisClusterCache>();

//把各个cache注册到cacheManager中,JedisClusterCache实现了org.springframework.cache.Cache接口
for(Caches c: Caches.values()){
caches.add(new JedisClusterCache(c.name(), jedisCluster, c.getTtl()));
}
cacheManager.setCaches(caches);
return cacheManager;
}
}


2、使用:
    /**
* 根据模块获取有效的、通用的广告列表
*
* @author XuJijun
* @param mType 广告模块
* @return
*/
@Override
@Cacheable("getCommonAds")
public List<Advert> getCommonAds(int mType) {
return advertDAO.getAdvertsByModuleType(mType);
}


注:@Cacheable注解里面指定了value=cacheName,这个注解的其他主要参数:
  • cacheManager:指定由哪个cacheManager(比如可以指定为"redisCacheManager")来管理这个cache,不指定的话使用spring注解@Primary的那个;
  • key:指定key的SpEL表达式,不指定的话,使用方法的参数作为key;
  • GuavaCache需要依赖Guava的jar包:
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>19.0</version>
</dependency>