【58沈剑架构系列】一分钟实现分布式锁

1、缘起node

分布式环境下,多台机器上多个进程对一个数据进行操做,若是不作互斥,就有可能出现“余额扣成负数”,或者“商品超卖”的状况,如何实现简易分布式锁,对分布式环境下的临界资源作互斥,是今天将要讨论的话题。redis

2、互斥原理缓存

原理:多个访问方对同一个资源进行操做,须要进行互斥,一般是利用一个这些访问方同时可以访问到的lock来实施互斥的。微信

例子1:同一个进程内,多个线程的互斥,典型的场景是生产者消费者对同一个queue进行操做时的互斥架构

方案:设定一个全部线程可以访问到的lock实施互斥分布式

步骤:ui

(1)多个线程同时抢锁操作系统

(2)只一个线程抢到,未抢到的阻塞,或下次再来抢线程

(3)抢到锁的线程操做临界资源blog

(4)操做完临界资源后释放锁

例子2:同一个操做系统上,多个进程的互斥,典型的场景是手机上多个APP对同一个文件进行写入互斥

方案:设定一个全部进程可以访问到的lock实施互斥(例如文件inode,OS帮咱们作了)

步骤:

(1)多个进程同时抢锁

(2)只一个进程抢到,未抢到的阻塞,或下次再来抢

(3)抢到锁的进程操做临界资源

(4)操做完临界资源后释放锁

3、分布式环境下多进程互斥

分布式环境下,多台机器上多个进程对一个数据进行操做的互斥,例如同一个uid=123要避免同时进行扣款。

根据上面的原理,先找一个多台机器多个进程能够同时访问到的一个lock,例如redis。

步骤:

(1)多台机器上多个进程对这个锁进行争抢,例如在缓存上同时进行set key=123操做

(2)只有一个进程会抢到这个锁,即只有一个进程对缓存set key=123可以成功,不成功的进程下次再来抢

(3)抢到锁的进程对余额进行扣减

(4)扣减完成以后释放锁,即对缓存delete key=123

分布式环境下的互斥,搞定。

 

【文章转载自微信公众号“架构师之路”】