1.x 设置
@Bean
@Primary
public CacheManager cacheManager(RedisTemplate redisTemplate) {
RedisCacheManager redisCacheManager = new RedisCacheManager(redisTemplate);
Map<String, Long> expires = new HashMap<>();
expires.put("timeout", 60L);
// 设置超时
// 根据特定名称设置有效时间
redisCacheManager.setExpires(expires);
// 设置默认的时间
redisCacheManager.setDefaultExpiration(cacheDefaultExpiration);
return redisCacheManager;
}
使用方式:
@Configuration
//@EnableRedisHttpSession(maxInactiveIntervalInSeconds = 3600 * 12)//最大过期时间
@EnableCaching
public class RedisConfig {
@Bean
public CacheManager cacheManager(RedisTemplate redisTemplate) {
RedisCacheManager rcm = new RedisCacheManager(redisTemplate);
//设置缓存过期时间
Map<String, Long> expires = new HashMap<>();
expires.put("12h", 3600 * 12L);
expires.put("1h", 3600 * 1L);
expires.put("10m", 60 * 10L);
rcm.setExpires(expires);
// rcm.setDefaultExpiration(60 * 60 * 12);//默认过期时间
return rcm;
}
}
//----------------------------------------------------------
@Cacheable(value = "12h", key = "#root.methodName")
@Override
public List<User> getUserArticleRank() {
//获得排行榜前10名的用户,每12小时刷新一次
return userRepository.findTop10ByArticleSize();
}
2.x 设置
/**
* 2.XX版本的配置
*
*/
@Bean
public CacheManager cacheManager(RedisConnectionFactory factory) {
RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig(); // 生成一个默认配置,通过config对象即可对缓存进行自定义配置
config = config.entryTtl(Duration.ofMinutes(2)) // 设置缓存的默认过期时间,也是使用Duration设置
.disableCachingNullValues(); // 不缓存空值
// 设置一个初始化的缓存空间set集合
Set<String> cacheNames = new HashSet<>();
cacheNames.add("catalog_test_id");
cacheNames.add("catalog_test_name");
// 对每个缓存空间应用不同的配置
Map<String, RedisCacheConfiguration> configMap = new HashMap<>();
configMap.put("catalog_test_id", config);
configMap.put("catalog_test_name", config.entryTtl(Duration.ofMinutes(5)));
RedisCacheManager cacheManager = RedisCacheManager.builder(factory) // 使用自定义的缓存配置初始化一个cacheManager
.initialCacheNames(cacheNames) // 注意这两句的调用顺序,一定要先调用该方法设置初始化的缓存名,再初始化相关的配置
.withInitialCacheConfigurations(configMap)
.build();
return cacheManager;
}
@CacheConfig(cacheNames = "catalog_test_name")
public class SsoCache{
@Cacheable(keyGenerator = "wiselyKeyGenerator")
public String getTokenByGsid(String gsid)
}
-------------------------------------
自定义Redis Cache 自动化配置替换系统默认的cacheManager
* 扩展cache name 支持 # 号分隔 cache name 和 超时 ttl(单位秒)。
<p>
* 示例:@CachePut(value = "user#300", key = "#id")
* </p>
参考:https://gitee.com/brucewuu/spring-ultron/blob/master/spring-ultron-projects/ultron-redis/src/main/java/org/springultron/redis/config/RedisCacheAutoConfiguration.java
---------------------------------------------------------
使用(name中增加“#”,后面是过期时间,不加则走默认时间)
@Cacheable(cacheNames = "catalog_test_name#120", unless = "#result==null")
public UserEntity findUserByUserName(String userName) {
return userRepository.findUserByUserName(userName);
}