java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > springboot redis cache TTL选项

springboot之redis cache TTL选项的使用

作者:sayyy

这篇文章主要介绍了springboot之redis cache TTL选项的使用方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

redis cache TTL 选项设置

获取 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参数。

配置多个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即可。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文