Springboot 的 @Cacheable注解的设置

Springboot的默认缓存注解用起来很方便,但是也有一些设置方面的问题

这个 @Cacheable 注解,默认会缓存null 值的,这个行为不是我的期望行为,可以通过设置避免此问题:

@Cacheable(value = "unitCache", key = "#unitId", unless="#result == null")

另外,这个cache默认是永久存储的,即使重启Eclipse也能读取缓存的值;如果测试的时候,需要手工清除:

    @CacheEvict(value = "unitCache", key = "#unitId")

最后,如果需要清除所有的缓存值的话,需要增加注解:

@CacheEvict(value = "unitCache", key = "#unitId", allEntries = true)

并且注意这个 allEntries  = true 的注解上 直接加 @PreDestroy 注解是无效的,需要在其他的bean里面的方法加上,调用这个加了 @CacheEvict(xxx,  allEntries = true)  的方法才有效

@PreDestroy

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
@Cacheable注解是Spring框架中用于缓存方法返回结果的注解。当一个方法被@Cacheable注解标记后,Spring会检查缓存中是否存在该方法的返回值,如果存在,则直接从缓存中获取结果并返回;如果不存在,则执行方法体,并将返回值存入缓存中。 使用@Cacheable注解需要注意以下几点: 1. 在需要缓存结果的方法上使用@Cacheable注解。 2. 可以指定缓存的名称,通过value属性来指定,如:@Cacheable(value="myCache")。 3. 可以指定缓存Key,通过key属性来指定,如:@Cacheable(key="#param")。其中#param表示方法的参数值,还可以使用SpEL表达式来动态构建key。 4. 默认情况下,缓存Key是由方法的所有参数组成的,如果不希望使用所有参数构建Key,可以使用condition属性来限制条件,如:@Cacheable(condition="#param.length() < 10")。这里的condition表示只有当参数长度小于10时才进行缓存。 5. 可以指定缓存的过期时间,通过设置expire属性来指定,如:@Cacheable(expire=3600)。单位为秒,默认为-1,表示永不过期。 示例代码: ```java @Service public class UserService { @Cacheable(value = "users", key = "#id") public User getUserById(String id) { // 从数据库中获取用户信息 // ... return user; } } ``` 上述示例中,getUserById方法会根据id参数从缓存中获取User对象,如果缓存中不存在,则执行方法体并将返回值存入缓存。 需要注意的是,@Cacheable注解只能用于Spring容器管理的Bean中,即被@Service、@Component等注解标记的类中的方法才能被缓存。另外,为了使@Cacheable注解生效,需要在Spring配置文件中配置缓存管理器(如使用Ehcache、Redis等)。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值