详细介绍项目开发中多种常用的分布式锁的实现以及分析比较。
分布式锁的常见应用场景,一般电商网站都会遇到秒杀、特价之类的活动,大促活动有一个共同特点就是访问量激增,在高并发下会出现成千上万人抢购一个商品的场景。虽然在系统设计时会通过限流、异步、排队等方式优化,但整体的并发还是平时的数倍以上,参加活动的商品一般都是限量库存,如何防止库存超卖,避免并发问题呢?分布式锁就是一个解决方案。
分布式锁就是为了对分布式环境下需要共享的资源进行保护,有了分布式锁的保护,代码的逻辑就会非常简单。但是很多情况下如果不用分布式锁的化也没有问题,但是各种race condition会让代码的逻辑特别复杂。使用了分布式锁可以保证在同一个时刻只能由一个进程在操作共享资源。
分布式锁的几种特性:
互斥性:和我们本地锁一样互斥性是最基本,但是分布式锁需要保证在不同节点的不同线程的互斥。
可重入性:同一个节点上的同一个线程如果获取了锁之后那么也可以再次获取这个锁。
锁超时:和本地锁一样支持锁超时,防止死锁。
高效,高可用:加锁和解锁需要高效,同时也需要保证高可用防止分布式锁失效,可以增加降级。
支持阻塞和非阻塞:和ReentrantLock一样支持lock和trylock以及tryLock(long timeOut)。
支持公平锁和非公平锁(可选):公平锁的意思是按照请求加锁的顺序获得锁,非公平锁就相反是无序的。
1. 分布式锁概述
2. 基于数据库的分布式锁
3.