@Synchronized 注解来自 Lombok,它的作用是 对当前方法加锁,确保同一时间只有一个线程可以执行该方法,并发时候需要等上一个执行才能进入。
@Synchronized 默认情况下,它会对整个方法进行同步控制,如果是静态方法,则会锁住类对象(MyClass.class)。
这意味着:
- 如果多个线程同时调用 yourMethod() 方法,
- 它们会 排队执行,不能并行处理;
- 这样可以保证线程安全,但可能带来性能瓶颈。
问题:
所有请求都串行化;
在高并发场景下(如热点 token),响应延迟显著上升;
出现线程阻塞、吞吐量下降等问题。
这个时候可以想想其他替代方案如并发加载机制,比喻Caffeine 提供的 LoadingCache
其效果:
当多个线程同时访问一个未缓存的 key 时,Caffeine 只会让 一个线程去加载数据,其他线程会等待并最终获取相同的结果(即 cache line locking);
不会出现所有线程都去查数据库/Redis 的情况(避免 缓存击穿);
性能远优于 synchronized 方法。