springboot之redis cache TTL选项的使用
作者:sayyy
这篇文章主要介绍了springboot之redis cache TTL选项的使用方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
redis cache TTL 选项设置
- 配置项: spring.cache.redis.time-to-live
- 单位: 毫秒
- 其它取值: java.time.Duration 可以识别的值
- 默认值: 缓存不过期
获取 TTL
@Service
public class xxx {
@Autowired
private CacheProperties cacheProperties;
public void xxx() {
Duration ttl = this.cacheProperties.getRedis().getTimeToLive();
if (null == ttl) {
// 未获取到ttl,按照默认值处理
} else {
// 获取到ttl
// ttl.getSeconds()
}
}
}SPRINGBOOT redis cache TTL配置多缓存解决
SPRINGBOOT 缓存的 TTL
Spring为了兼容多Cache,注解@Cacheable没有直接TTL参数。
- springboot 配置文件可以全局配置TTL
- 可以用@CacheEvict配合@Schedule清理
- 可以自定义RedisCacheManage,指定TTL
配置多个RedisCacheManage解决方案
可以简单配置2个redis cache,一个指定固定TTL,一个长期缓存。
不废话,上代码。
如果需要和其他系统公用缓存,用Jackson的RedisSerializer,这里直接jdk的序列化。
@Configuration
public class CacheConfig {
@Bean
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
RedisTemplate<String, Object> template = new RedisTemplate<>();
template.setConnectionFactory(factory);
template.setKeySerializer(new StringRedisSerializer());
template.setHashKeySerializer(new StringRedisSerializer());
template.setValueSerializer(new JdkSerializationRedisSerializer());
template.setHashValueSerializer(new JdkSerializationRedisSerializer());
return template;
}
@Bean(name = "RedisCacheManagerWithTTL")
public RedisCacheManager cacheManagerWithTTL(RedisConnectionFactory factory) {
RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()
.entryTtl(Duration.ofMinutes(2))
.serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(new StringRedisSerializer()))
.serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(new JdkSerializationRedisSerializer()))
.disableCachingNullValues();
RedisCacheManager.RedisCacheManagerBuilder builder = RedisCacheManager.RedisCacheManagerBuilder.fromConnectionFactory(factory);
return builder.transactionAware().cacheDefaults(config).build();
}
@Bean
@Primary
public RedisCacheManager cacheManager(RedisConnectionFactory factory) {
RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()
.serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(new StringRedisSerializer()))
.serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(new JdkSerializationRedisSerializer()))
.disableCachingNullValues();
RedisCacheManager.RedisCacheManagerBuilder builder = RedisCacheManager.RedisCacheManagerBuilder.fromConnectionFactory(factory);
return builder.transactionAware().cacheDefaults(config).build();
}
}使用
如果需要TTL,使用注解
@Cacheable(cacheNames = "YOUR:CACHE:NAME", cacheManager = "RedisCacheManagerWithTTL")
或者类上使用
@CacheConfig(cacheManager = "RedisCacheManagerWithTTL")
需要长期存储的,使用 默认cacheManager即可。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
