一、缘起
分布式环境下,多台机器上多个进程对一个数据进行操作,如果不做互斥,就有可能出现“余额扣成负数”,或者“商品超卖”的情况,如何实现简易分布式锁,对分布式环境下的临界资源做互斥,是今天将要讨论的话题。
二、互斥原理
原理:多个访问方对同一个资源进行操作,需要进行互斥,通常是利用一个这些访问方同时能够访问到的lock来实施互斥的。
例子1:同一个进程内,多个线程的互斥,典型的场景是生产者消费者对同一个queue进行操作时的互斥

方案:设定一个所有线程能够访问到的lock实施互斥

步骤:
(1)多个线程同时抢锁
(2)只一个线程抢到,未抢到的阻塞,或下次再来抢
(3)抢到锁的线程操作临界资源
(4)操作完临界资源后释放锁
例子2:同一个操作系统上,多个进程的互斥,典型的场景是手机上多个APP对同一个文件进行写入互斥

方案:设定一个所有进程能够访问到的l
继续阅读与本文标签相同的文章
上一篇 :
即使删了全库,保证半小时恢复
下一篇 :
这才是真正的分布式锁
-
一分钟掌握数据库垂直拆分
2026-05-20栏目: 教程
-
这才是真正的表扩展方案
2026-05-20栏目: 教程
-
啥,又要为表增加一列属性?
2026-05-20栏目: 教程
-
这才是真正的分布式锁
2026-05-20栏目: 教程
-
一分钟实现分布式锁
2026-05-20栏目: 教程
