尚硅谷bilibili官方视频教程: bilibili.com/video/BV1Rv41177Af?p=43
问题描述
随着业务发展的需要,原单体单机部署的系统被演化成分布式集群系统后,由于分布式系统多线程、多进程并且分布在不同机器上,这将使原单机部署情况下的并发控制锁策略失效,单纯的Java API并不能提供分布式锁的能力。为了解决这个问题就需要一种跨JVM的互斥机制来控制共享资源的访问,这就是分布式锁要解决的问题!
分布式锁主流的实现方案:
- 基于数据库实现分布式锁
- 基于缓存(Redis等)
- 基于Zookeeper
每一种分布式锁解决方案都有各自的优缺点: - 性能:redis最高
- 可靠性:zookeeper最高
这里,我们就基于redis实现分布式锁。
redis实现分布式锁
setnx命令
通过setnx命令设置锁,当设置锁之后需要通过del命令将锁释放
使用上述方式每次都要手动释放锁,我们可以通过命令expire设置这个锁的过期时间,就不用每次都要手动释放锁了。
但这样无法保证操作的原子操作,假设设置锁之后还没设置过期时间突然这台服务器宕机了这样这把锁会一直锁着得不到释放,我们可以通过上锁的时候同时设置锁的过期时间就可以保证操作的原子性了。