SpringCache 给不同的key设置不同的过期时间

10 篇文章 0 订阅
2 篇文章 0 订阅

前言

spring cache可以使用注解来很方便的操作缓存,但是它的过期时间配置却是统一的,如何自定义每个key的过期时间?

关键点

以springboot+redis为例,使用注解来操作redis之前需要有一个redis配置类

@Configuration
//@EnableConfigurationProperties({Properties.class})
@EnableCaching
public class RedisConfig {

    @Bean
    public CacheManager cacheManager(RedisConnectionFactory connectionFactory) {
        
    }

}

对redis的操作都交给了这个CacheManager的Bean来完成
包括对key的管理,超时时间的设置等都可以在这里进行配置

实现

  • 在配置文件中定义key的过期时间
server.port=8080
spring.redis.database=2
spring.redis.host=127.0.0.1
#spring.redis.password=123456
spring.redis.port=6379

initCaches.key1 = 10s
initCaches.key2 = 20s
  • 定义一个配置类映射配置文件的key
@Component
@ConfigurationProperties
public class Properties {

    private final Map<String, Duration> initCaches = new HashMap<>();

    public Map<String, Duration> getInitCaches() {
        return initCaches;
    }
}
  • redis配置类
@Configuration
//@EnableConfigurationProperties({Properties.class})
@EnableCaching
public class RedisConfig {

    @Autowired
    private Properties properties;

    @Bean
    public CacheManager cacheManager(RedisConnectionFactory connectionFactory) {
        RedisCacheConfiguration defaultCacheConfig = RedisCacheConfiguration.defaultCacheConfig()
                .entryTtl(Duration.ofMinutes(10)).disableCachingNullValues();

        RedisCacheWriter redisCacheWriter = RedisCacheWriter.nonLockingRedisCacheWriter(connectionFactory);

        Set<String> cacheNames =new HashSet<>();
        ConcurrentHashMap<String,RedisCacheConfiguration>cacheConfig = new ConcurrentHashMap<>();
        for (Map.Entry<String, Duration> entry : properties.getInitCaches().entrySet()) {
            cacheNames.add(entry.getKey());
            cacheConfig.put(entry.getKey(), defaultCacheConfig.entryTtl(entry.getValue()));
        }

        return RedisCacheManager.builder(redisCacheWriter)
                .cacheDefaults(defaultCacheConfig)
                .initialCacheNames(cacheNames)
                .withInitialCacheConfigurations(cacheConfig)
                .build();
    }

}

其实核心属性就是两个集合:cacheNames和cacheconfigurations

  • 测试
  @GetMapping("/put1")
    @Cacheable(value = "key1", key = "#id")
    public String putKey1(String id) {
        return "key1Value";
    }
    @GetMapping("/put2")
    @Cacheable(value = "key2", key = "#id")
    public String putKey2(String id) {
        return "key2Value";
    }

value就是配置文件定义的key,key是支持#spel表达式的,方法必须带有参数。

测试结果key1过期时间为10s,key2过期时间为20s

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
Spring CacheSpring框架提供的一种缓存机制,用于提高应用程序的性能和响应速度。通过使用Spring Cache,可以将方法的返回值缓存起来,当下次调用相同的方法时,可以直接从缓存中获取结果,而不需要再执行方法的逻辑。 在使用Spring Cache时,需要进行一些配置。首先,需要添加Redis的配置信息,包括缓存类型、缓存过期时间缓存键的前缀等。可以通过设置`spring.cache.type`为`redis`来指定使用Redis作为缓存类型。可以使用`spring.cache.redis.time-to-live`设置缓存过期时间,单位为毫秒。可以使用`spring.cache.redis.key-prefix`设置缓存键的前缀,如果不指定前缀,则默认使用缓存的名字作为前缀。可以使用`spring.cache.redis.use-key-prefix`设置是否使用前缀,默认为true。可以使用`spring.cache.redis.cache-null-values`设置是否缓存空值,以防止缓存穿透。 另外,Spring Cache还支持使用JCache(JSR-107)注解来简化开发。从Spring 3.1开始,定义了`org.springframework.cache.Cache`和`org.springframework.cache.CacheManager`接口来统一不同缓存技术。 在使用Spring Cache时,可以通过在方法上添加`@Cacheable`注解来启用缓存功能。当调用带有`@Cacheable`注解的方法时,Spring会首先检查缓存中是否存在相应的结果,如果存在,则直接返回缓存中的结果,如果不存在,则执行方法的逻辑,并将结果存入缓存中。 总结起来,使用Spring Cache可以通过配置Redis等缓存信息,并在方法上添加`@Cacheable`注解来实现缓存功能,提高应用程序的性能和响应速度。 #### 引用[.reference_title] - *1* [SpringCache的使用](https://blog.csdn.net/ABestRookie/article/details/121297482)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [springcache的使用详解(使用redis做分布式缓存)](https://blog.csdn.net/A_art_xiang/article/details/125580962)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值