[发明专利]分布式系统中全局锁的实现方法及装置有效
申请号: | 201611131371.9 | 申请日: | 2016-12-09 |
公开(公告)号: | CN106598746B | 公开(公告)日: | 2021-04-23 |
发明(设计)人: | 赵安安 | 申请(专利权)人: | 北京奇虎科技有限公司 |
主分类号: | G06F9/52 | 分类号: | G06F9/52 |
代理公司: | 深圳市世纪恒程知识产权代理事务所 44287 | 代理人: | 胡海国 |
地址: | 100088 北京市西城区新*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 分布式 系统 全局 实现 方法 装置 | ||
本发明公开了一种分布式系统中全局锁的实现方法及装置,其方法包括:获取与所要执行的操作对应的全局锁;判断全局锁是否被锁定;若否,锁定全局锁,执行全局锁对应的操作。分布式系统中在要执行操作前获取与要执行的操作对应的全局锁,若该全局锁没有被锁定的情况下,锁定全局锁,执行全局锁对应的操作。利用本发明方案,实现了在分布式系统中,基于一致性,将操作与全局锁对应,通过锁定全局锁执行相应的操作。进一步,也避免发生分布式系统中多节点间操作并发冲突、死锁等问题。
技术领域
本发明涉及计算机软件领域,具体涉及一种分布式系统中全局锁的实现方法及装置。
背景技术
分布式系统建立在网络基础之上,由一组各自独立的多个节点如服务器组成统一的整体。分布式系统中多个节点并行运行,在同一时刻可能存在多个节点或一个节点中的多个进程对某一对象进行操作的请求。需要对这种操作的请求进行管理,以避免对该对象进行了重复操作或操作顺序不当等原因造成的数据被破坏、进程间死锁等问题。
现有的锁管理大多基于单个节点实现,如在对某一对象进行如数据处理、文件处理等各种处理操作时,如果同时单个节点中的多个进程对该对象有多个操作请求,可以通过锁获取对该对象的操作。实现单个节点系统中的同步、互斥等操作。但分布式系统具有多个节点,各节点间均各自独立。因此,不能通过单个节点自身的锁来实现对整个分布式系统的操作的管理。基于以上情况,在分布式系统中需要对多个节点实现操作管理。全局锁可以对分布式系统中多个节点的操作进行管理,需要在分布式系统中实现全局锁,从而实现分布式系统中多个节点的操作管理。
发明内容
鉴于上述问题,提出了本发明以便提供一种克服上述问题或者至少部分地解决上述问题的分布式系统中全局锁的实现方法及装置。
根据本发明的一个方面,提供了一种分布式系统中全局锁的实现方法,其包括:
获取与所要执行的操作对应的全局锁;
判断全局锁是否被锁定;
若否,锁定全局锁,执行全局锁对应的操作。
根据本发明的另一方面,提供了一种分布式系统中全局锁的实现装置,其包括:
获取模块,适于获取与所要执行的操作对应的全局锁;
第一判断模块,适于判断全局锁是否被锁定;
执行模块,适于若第一判断模块判断出全局锁未被锁定,则锁定全局锁,执行全局锁对应的操作。
根据本发明提供的分布式系统中全局锁的实现方法及装置,获取与所要执行的操作对应的全局锁,判断全局锁是否被锁定。在没有被锁定的情况下,锁定全局锁,执行全局锁对应的操作。分布式系统中在要执行操作前获取与要执行的操作对应的全局锁,若该全局锁没有被锁定的情况下,锁定全局锁,执行全局锁对应的操作。利用本发明方案,实现了在分布式系统中,基于一致性,将操作与全局锁对应,通过锁定全局锁执行相应的操作。进一步,也避免发生分布式系统中多节点间操作并发冲突、死锁等问题。
上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。
附图说明
通过阅读下文优选实施方式的详细描述,各种其他的优点和益处对于本领域普通技术人员将变得清楚明了。附图仅用于示出优选实施方式的目的,而并不认为是对本发明的限制。而且在整个附图中,用相同的参考符号表示相同的部件。在附图中:
图1示出了根据本发明一个实施例的分布式系统中全局锁的实现方法的流程图;
图2示出了根据本发明另一个实施例的分布式系统中全局锁的实现方法的流程图;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京奇虎科技有限公司,未经北京奇虎科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201611131371.9/2.html,转载请声明来源钻瓜专利网。
- 上一篇:线程管理方法和系统
- 下一篇:网络数据包的并行处理方法及装置