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即可。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。