Spring Cache sync属性

在Spring Cache中,@Cacheable注解用于标记一个方法,使其返回值可以被缓存。sync属性是Spring 4.3引入的一个新特性,用于控制缓存的同步行为。

sync 属性

sync属性的默认值是false,表示异步缓存。如果将sync设置为true,则表示同步缓存。

异步缓存(sync = false

sync属性为false时,如果多个线程同时请求同一个缓存键,并且该键在缓存中不存在,所有线程都会执行缓存方法,可能会导致缓存击穿(Cache Penetration)。

同步缓存(sync = true

sync属性为true时,如果多个线程同时请求同一个缓存键,并且该键在缓存中不存在,只有一个线程会执行缓存方法,其他线程会等待该线程执行完毕并将结果放入缓存。这种方式可以有效防止缓存击穿。

示例

以下是一个使用@Cacheable注解的示例,其中sync属性设置为true

import org.springframework.cache.annotation.Cacheable;
import org.springframework.stereotype.Service;

@Service
public class NotifyFrequencyService {

    @Cacheable(value = "notifyCacheManager", key = "#id", cacheManager = "notifyCacheManager", sync = true)
    public String getNotifyFrequencyClassify(String id) {
        // 模拟一个耗时操作
        try {
            Thread.sleep(3000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        return "Frequency for ID: " + id;
    }
}

在这个示例中,当多个线程同时请求getNotifyFrequencyClassify方法并且缓存中没有对应的键时,只有一个线程会执行该方法,其他线程会等待结果被缓存。

总结

sync = true 表示同步缓存,防止缓存击穿。当多个线程同时请求同一个缓存键并且该键在缓存中不存在时,只有一个线程会执行缓存方法,其他线程会等待结果被缓存。这种方式可以有效提高缓存的性能和稳定性。

  • 5
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

你这个代码我看不懂

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值