对请求进行加解锁方法、装置及系统的制作方法

文档序号:9711451阅读:303来源:国知局
对请求进行加解锁方法、装置及系统的制作方法
【技术领域】
[0001]本发明涉及互联网技术领域,尤其涉及一种对请求进行加解锁方法、装置及系统。
【背景技术】
[0002]为了保证数据的一致和完整性,对于任何的数据库都会设计数据库锁机制来使各种共享的资源在并发访问时可以有序的进行。拿数据库MySQL来说,MySQL自身也带有锁机制。具体的锁机制的实现过程是:在客户端访问MySQL中的某条数据时,首先需要与MySQL建立传输控制协议(Transmiss1n Control Protocol,简称TCP)连接,然后由MySQL进行自检,即查询该条数据是否处于锁状态;若该条数据没有被锁,则客户端可以继续访问该条数据,若该条数据被锁,则客户端进入等待状态,直到访问的数据被解锁后客户端才可以继续访问。
[0003]在上述MySQL进行自检时,由于MySQL中的锁机制是进行行级锁定或页级锁定或表级锁定的,所以首先需要查询该条数据属于哪个表或者哪页或者哪行的数据,然后再判断该数据所在的行或页或表是否被锁。实际应用中,数据库中的数据量十分庞大,上述数据库的锁机制会造成数据库自检时资源消耗很大,因此效率低下。

【发明内容】

[0004]鉴于上述问题,提出了本发明以便提供一种克服上述问题或者至少部分地解决上述问题的对请求进行加解锁方法、装置及系统。
[0005]为解决上述技术问题,一方面,本发明提供了一种对请求进行加解锁方法,方法应用于管理服务器侧,包括:
[0006]接收客户端发送的服务请求,所述服务请求用于请求访问目标服务器;
[0007]判断所述服务请求对应的资源是否被占用,所述资源是在目标服务器中的资源;
[0008]若所述资源没有被占用,则向所述客户端发送访问指令,所述访问指令用于指示所述客户端访问所述目标服务器;
[0009]若所述资源被占用,则不响应所述服务请求,以使所述客户端处于等待状态。
[0010]第二方面,本发明还提供了一种对请求进行加解锁方法,方法应用于客户端侧,包括:
[0011]向管理服务器发送服务请求,所述服务请求用于请求访问目标服务器;
[0012]等待所述管理服务器发送的访问指令,所述访问指令用于指示所述客户端访问所述目标服务器;
[0013]若接收到所述访问指令,则访问所述目标服务器;
[0014]若接收不到所述访问指令,则继续等待。
[0015]第三方面,本发明还提供了一种对请求进行加解锁的装置,所述装置位于管理服务器侧,包括:
[0016]请求接收单元,用于接收客户端发送的服务请求,所述服务请求用于请求访问目标服务器;
[0017]判断单元,用于判断所述服务请求对应的资源是否被占用,所述资源是在目标服务器中的资源;
[0018]访问指令发送单元,用于若所述资源没有被占用,则向所述客户端发送访问指令,所述访问指令用于指示所述客户端访问所述目标服务器;
[0019]等待单元,用于若所述资源被占用,则不响应所述服务请求,以使所述客户端处于等待状态。
[0020]第四方面,本发明还提供了一种对请求进行加解锁的装置,所述装置位于客户端侧,包括:
[0021 ]请求发送单元,用于向管理服务器发送服务请求,所述服务请求用于请求访问目标服务器;
[0022]第一等待单元,用于等待所述管理服务器发送的访问指令,所述访问指令用于指示所述客户端访问所述目标服务器;
[0023]访问单元,用于若接收到所述访问指令,则访问所述目标服务器;
[0024]第二等待单元,用于若接收不到所述访问指令,则继续等待。
[0025]第五方面,本发明还提供了一种对请求进行加解锁的系统,该系统包括:管理服务器和客户端;
[0026]所述管理服务器,用于接收所述客户端发送的服务请求,所述服务请求用于请求访问目标服务器;并判断所述服务请求对应的资源是否被占用,所述资源是在目标服务器中的资源;若所述资源没有被占用,则向所述客户端发送访问指令,所述访问指令用于指示所述客户端访问所述目标服务器;若所述资源被占用,则不响应所述服务请求,以使所述客户端处于等待状态;
[0027]所述客户端,用于向所述管理服务器发送所述服务请求;等待所述管理服务器发送的访问指令;若接收到所述访问指令,则访问所述目标服务器;若接收不到所述访问指令,则继续等待。
[0028]借由上述技术方案,本发明提供的对请求进行加解锁的方法、装置及系统,能够通过管理服务器接受客户端用于访问目标服务器的服务请求,然后由管理服务器先判断该服务请求对应的在目标服务器中的资源是否被占用,若资源被占用,就不向客户端发送访问目标服务器的访问指令,客户端处于等待状态,若资源未被占用则项客户端发送访问指令,使客户端可以访问目标服务器。与现有技术相比,本发明使目标服务器中的同一个资源每次只允许有一个客户端进行访问,在该资源在被占用的情况下,其他的客户端就需要等待,即实现了资源的加解锁管理。另外加解锁的管理是通过独立的管理服务器实现的,减轻了在目标服务器中实现加解锁造成的资源消耗,因此提高了加解锁的效率。
[0029]上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的【具体实施方式】。
【附图说明】
[0030]通过阅读下文优选实施方式的详细描述,各种其他的优点和益处对于本领域普通技术人员将变得清楚明了。附图仅用于示出优选实施方式的目的,而并不认为是对本发明的限制。而且在整个附图中,用相同的参考符号表示相同的部件。在附图中:
[0031]图1示出了本发明实施例提供的一种对请求进行加解锁的方法流程图;
[0032]图2示出了本发明实施例提供的另一种对请求进行加解锁的方法流程图;
[0033]图3示出了本发明实施例提供的又一种对请求进行加解锁的方法流程图;
[0034]图4示出了本发明实施例提供的再一种对请求进行加解锁的方法流程图;
[0035]图5示出了本发明实施例提供的一种对请求进行加解锁的装置的组成框图;
[0036]图6示出了本发明实施例提供的另一种对请求进行加解锁的装置的组成框图;
[0037]图7示出了本发明实施例提供的又一种对请求进行加解锁的装置的组成框图;
[0038]图8示出了本发明实施例提供的再一种对请求进行加解锁的装置的组成框图;
[0039]图9示出了本发明实施例提供的一种对请求进行加解锁的系统框图。
【具体实施方式】
[0040]下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
[0041]为解决现有数据库锁机制效率低下的问题,本发明实施例提供了一种对请求进行加解锁的方法,如图1所示,该方法应用于管理服务器侧,该方法包括:
[0042]101、接收客户端发送的服务请求。
[0043]管理服务器接收客户端发送的服务请求,该服务请求用于请求访问目标服务器。需要说明的是,在接收客户端发送的服务请求之前必须与客户端建立TCP连接,然后通过TCP连接接收客户端发送的服务请求。TCP连接的建立是客户端与管理服务器之间进行后续所有通讯的桥梁。
[0044]102、判断服务请求对应的资源是否被占用。
[0045]需要说明的是对于步骤101中接收到的服务请求对应的资源是不能被不同的客户端同时进行访问的。所以需要首先判断服务请求对应的资源是否被占用。
[0046]具体的判断资源是否被占用的方法为:提前为目标服务器中的该资源设置一个锁;当该资源被占用时,该锁也处于被占用的状态,当该资源未被占用时,该锁也处于未被占用的状态;然后通过判断资源对应的锁是否被占用来判断资源是否被占用。
[0047]103、若资源没有被占用,则向客户端发送访问指令。
[0048]若管理服务器判断服务请求中对应的资源未被占用,则会向发送服务请求的客户端发送访问指令,该访问指令用于告知客户端可以访问目标服务器。
[0049]104、若资源被占用,则不响应服务请求。
[0050]若管理服务器判断服务请求中对应的资源被占用,则不会响应客户端发送的服务请求,使发送服务请求的客户端处于等待状态。
[0051]本实施例提供的对请求进行加解锁的方法,能够通过管理服务器接受客户端用于访问目标服务器的服务请
当前第1页1 2 3 4 5 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1