[发明专利]分布式系统中分布式锁调度方法及装置在审
申请号: | 202110182313.3 | 申请日: | 2021-02-10 |
公开(公告)号: | CN113296904A | 公开(公告)日: | 2021-08-24 |
发明(设计)人: | 刘扬宽;吕建枢 | 申请(专利权)人: | 阿里巴巴集团控股有限公司 |
主分类号: | G06F9/48 | 分类号: | G06F9/48;G06F9/50 |
代理公司: | 北京智信禾专利代理有限公司 11637 | 代理人: | 吴肖肖 |
地址: | 英属开曼群岛大开*** | 国省代码: | 暂无信息 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 分布式 系统 调度 方法 装置 | ||
1.一种分布式系统中分布式锁调度方法,所述分布式系统包括分布式锁申请节点、分布式锁主管节点和分布式锁持有节点;
所述方法包括:
所述分布式锁申请节点在所述当前节点的授权状态为未授权的情况下,向所述分布式锁主管节点发送所述目标资源的分布式锁请求;
所述分布式锁主管节点读取所述目标资源的分布式锁授权列表,在所述分布式授权列表中存在所述分布式锁持有节点的节点标识的情况下,向所述分布式锁持有节点发送分布式锁召回请求;
所述分布式锁持有节点响应于所述分布式锁召回请求确定当前节点的本地锁的使用状态,在所述当前节点的本地锁的使用状态为释放状态的情况下,向所述分布式锁主管节点发送分布式锁归还信息并将当前节点的授权状态设置为未授权;
所述分布式锁主管节点在接收到所述分布式锁归还信息的情况下,向所述分布式锁申请节点发送所述目标资源的分布式锁授权指令,并在所述目标资源的分布式锁授权列表中记录所述分布式锁申请节点的节点标识;
所述分布式锁申请节点响应于所述分布式锁授权指令将当前节点的授权状态设置为授权。
2.如权利要求1所述的分布式系统中分布式锁调度方法,所述方法还包括:
所述分布式锁申请节点接收目标资源的访问请求,响应于所述访问请求检查所述目标资源的分布式锁在当前节点的授权状态。
3.如权利要求1所述的分布式系统中分布式锁调度方法,在所述分布式锁申请节点响应于所述分布式锁授权指令将当前节点的授权状态设置为授权之后,所述方法还包括:
所述分布式锁申请节点加载当前节点的本地锁,并通过所述当前节点的本地锁访问所述目标资源。
4.如权利要求1所述的分布式系统中分布式锁调度方法,所述方法还包括:
所述分布式锁申请节点在所述当前节点的授权状态为授权的情况下,加载当前节点的本地锁,通过所述当前节点的本地锁访问所述目标资源。
5.如权利要求3或4所述的分布式系统中分布式锁调度方法,在所述分布式锁申请节点加载当前节点的本地锁之后,所述方法还包括:
所述分布式锁申请节点监控所述当前节点的本地锁的占用数量。
6.如权利要求1所述的分布式系统中分布式锁调度方法,在所述分布式锁申请节点响应于所述分布式锁授权指令将当前节点的授权状态设置为授权之后,所述方法还包括:
所述分布式锁申请节点被设置为新的分布式锁持有节点。
7.如权利要求1所述的分布式系统中分布式锁调度方法,所述方法还包括:
所述分布式锁主管节点将所述分布式锁申请节点的节点标识添加到分布式锁等待队列。
8.如权利要求7所述的分布式系统中分布式锁调度方法,所述分布式锁主管节点向所述分布式锁申请节点发送所述目标资源的分布式锁授权指令,包括:
所述分布式锁主管节点从所述分布式锁等待队列中获取所述分布式锁申请节点的节点标识,向所述分布式锁申请节点的节点标识对应的分布式锁申请节点发送所述目标资源的分布式锁授权指令。
9.如权利要求1所述的分布式系统中分布式锁调度方法,所述分布式锁持有节点响应于所述分布式锁召回请求确定当前节点的本地锁的使用状态,包括:
所述分布式锁持有节点响应于所述分布式锁召回请求获取当前节点的本地锁的占用数量,在所述占用数量为0的情况下,确定当前节点的本地锁的使用状态为释放状态,在所述占用数量非0的情况下,确定当前节点的本地锁的使用状态为加载状态。
10.如权利要求1所述的分布式系统中分布式锁调度方法,在所述分布式锁持有节点向所述分布式锁主管节点发送分布式锁归还信息之前,所述方法还包括:
所述分布式锁持有节点同步所述目标资源的更新信息,在所述目标资源的更新信息同步完成的情况下,向所述分布式锁主管节点发送分布式锁归还信息。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于阿里巴巴集团控股有限公司,未经阿里巴巴集团控股有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202110182313.3/1.html,转载请声明来源钻瓜专利网。