1.建立连接

客户端连接 etcd,以 /etcd/lock 为前缀创建全局唯一的 key,

假设第一个客户端对应的 key="/etcd/lock/UUID1",第二个为 key="/etcd/lock/UUID2";

客户端分别为自己的 key 创建租约 - Lease,租约的长度根据业务耗时确定;

2.创建定时任务作为租约的“心跳”

当一个客户端持有锁期间,其它客户端只能等待,为了避免等待期间租约失效,

客户端需创建一个定时任务作为“心跳”进行续约。此外,如果持有锁期间客户端崩溃,

心跳停止,key 将因租约到期而被删除,从而锁释放,避免死锁;

3.客户端将自己全局唯一的 key 写入 etcd

执行 put 操作,将步骤 1 中创建的 key 绑定租约写入 Etcd,根据 Etcd 的 Revision 机制,

假设两个客户端 put 操作返回的 Revision 分别为 1、2,客户端需记录 Revision 用以

接下来判断自己是否获得锁;

4.客户端判断是否获得锁

客户端以前缀 /etcd/lock/ 读取 key-Value 列表,判断自己 key 的 Revision 是否为当前列表中

最小的,如果是则认为获得锁;否则监听列表中前一个 Revision 比自己小的 key 的删除事件,一旦监听到删除事件或者因租约失效而删除的事件,则自己获得锁

5.执行业务

获得锁后,操作共享资源,执行业务代

6.释放锁

完成业务流程后,删除对应的key释放锁

Logo

鸿蒙生态一站式服务平台。

更多推荐