一种分布式系统的资源访问方法和系统的制作方法

文档序号:7889466阅读:154来源:国知局
专利名称:一种分布式系统的资源访问方法和系统的制作方法
技术领域
本申请涉及网络数据处理领域,特别涉及一种分布式系统的资源访问方法和系统。
背景技术
分布式系统(distributed system)是建立在网络之上的软件系统。由于多数分布式系统是建立在计算机网络之上的,所以分布式系统与计算机网络在物理结构上是基本相同的。分布式系统在运行程序时,可以将程序交由系统中的多台计算机同时运行。在分布式系统中的多台计算机同时运行某一程序时,可能会出现多台计算机同时访问某一数据的情况。这在本领域中通常称为资源的并发访问。因为计算机在访问到请求的数据后,可能会对数据进行修改,所以,为了避免多台计算机同时对某一数据进行修改所导致的数据错误,应当尽量防止对资源的并发访问。为了防止在分布式系统中对资源的并发访问,现有技术中的分布式系统的资源访问方法主要是利用Memcache系统的锁功能。具体实现时,Memcache系统的锁功能的原理主要是:在一台计算机访问某个资源之前,先尝试锁住Memcache系统中的一个字符串;如果该字符串已经处于锁定状态,则说明该资源正在被其他计算机访问,则当前的这台计算机对该资源的访问失败,否则说明该资源没有被其他计算机访问,则由当前的这台计算机锁住该字符串后,就可以访问该资源,也能够避免其他计算机后续再访问该资源时会出现访问失败的情况。但是,由于现有技术中的分布式系统的资源访问方法对Memcache系统的可靠性要求较高,所以如果Memcache系统出错,仍然会发生资源的并发访问。例如Memcache系统重启后对某资源的锁信息丢失,则其他计算机查询该资源的字符串是否处于锁定状态时,就会误认为该字符串处于未锁定状态。然而Memcache系统重启前,该资源的字符串是处于锁定状态的,这表示有另外的计算机在访问该资源,此时就会发生不同的计算机对资源进行并发访问的问题。总之,目前需要本领域技术人员迫切解决的一个技术问题就是:如何能够创新的提出一种分布式系统的资源访问方法,以解决现有技术中无法有效防止在访问分布式系统的资源时,出现的对资源并发访问的问题。申请内容本申请所要解决的技术问题是提供一种分布式系统的资源访问方法,用以解决现有技术中不同的计算机在访问分布式系统的资源时,出现的对资源并发访问的问题。

本申请还提供了一种分布式系统的资源访问系统,用以保证上述方法在实际中的实现及应用。为了解决上述问题,本申请公开了一种分布式系统的资源访问方法,所述分布式系统中的各台服务器具有与所述资源一一对应的互斥锁标识,所述互斥锁标识具有锁定状态与未锁定状态,所述方法包括:
在访问所述资源之前,当前服务器将所述资源的位于本地的当前互斥锁标识设置为所述锁定状态;所述当前服务器请求所述分布式系统中的其他服务器将所述资源相对应的其他互斥锁标识设置为锁定状态;所述当前服务器判断所述分布式系统中的其他服务器对所述其他互斥锁标识是否锁定成功;如果是,则所述当前服务器访问所述资源。优选的,所述将所述资源的位于本地的当前互斥锁标识设置为所述锁定状态,包括:查找所述资源的资源标识;所述资源标识与所述资源一一对应;根据预先设定的资源标识与互斥锁标识之间的映射关系,确定所述资源的位于本地的当前互斥锁标识;将所述当前互斥锁标识设置为所述锁定状态。优选的,所述当前服务器请求分布式系统中的其他服务器将所述资源相对应的其他互斥锁标识设置为锁定状态,包括:所述当前服务器从预先保存的并发访问控制列表中读取需要设置互斥锁标识状态的服务器地址信息;所述并发访问控制列表中存储有存在并发访问冲突的服务器地址信息;根据所述服务器地址信息,所述当前服务器向需要设置互斥锁标识状态的服务器发送访问所述资源的请求,以便所述需要设置互斥锁标识状态的服务器接收到所述请求后,尝试将本地的所述互斥锁标识设置为锁定状态;所述当前服务器接收所述需要设置互斥锁标识状态的服务器发送的表示设置成功的反馈信息;则所述判断所述分布式系统中的其他服务器与所述资源相对应的所述互斥锁标识是否锁定成功,具体包括:判断是否接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信息。优选的,所述判断是否接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信息,具体包括:判断是否在第一预设时间内接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信息。优选的,在分布式系统中的其他服务器对与所述其他互斥锁标识未锁定成功的情况下,所述方法还包括:所述当前服务器判断是否到达第二预设时间,如果是,则执行所述当前服务器将所述资源的位于本地的当前互斥锁标识设置为所述锁定状态的步骤。本申请还提供了一种分布式系统的资源访问系统,所述分布式系统中的各台服务器具有与所述资源一一对应的互斥锁标识,所述互斥锁标识具有锁定状态与未锁定状态,所述资源访问系统包括:本地标识锁定单元,用于在访问所述资源之前,将所述资源的位于本地的当前互斥锁标识设置为所述锁定 状态;
其他标识锁定请求单元,用于请求所述分布式系统中的其他服务器将所述资源相对应的其他互斥锁标识设置为锁定状态;第一判断单元,用于判断所述分布式系统中的其他服务器对所述其他互斥锁标识是否锁定成功;访问单元,用于当所述第一判断单元的判断结果为是时,访问所述资源。优选的,所述本地标识锁定单元,包括:资源标识查找子单元,用于查找所述资源的资源标识;所述资源标识与所述资源--对应;互斥锁标识确定子单元,用于根据预先设定的资源标识与互斥锁标识之间的映射关系,确定所述资源的位于本地的当前互斥锁标识;互斥锁标识锁定子单元,用于将所述当前互斥锁标识设置为所述锁定状态。优选的,所述其他标识锁定请求单元,包括:地址信息读取子单元,用于从预先保存的并发访问控制列表中读取需要设置互斥锁标识状态的服务器地址信息;所述并发访问控制列表中存储有存在并发访问冲突的服务器地址信息;锁定请求发送子单元,用于根据所述服务器地址信息,向需要设置互斥锁标识状态的服务器发送访问所述 资源的请求;反馈信息接收子单元,用于接收所述需要设置互斥锁标识状态的服务器发送的表示设置成功的反馈信息;以便所述需要设置互斥锁标识状态的服务器接收到所述请求后,尝试将本地的所述互斥锁标识设置为锁定状态;所述第一判断单元,具体包括:第一判断子单元,用于判断是否接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信息。优选的,所述第一判断子单元具体包括:计时判断子单元,用于判断是否在第一预设时间内接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信息。优选的,还包括:计时判断单元,用于在分布式系统中的其他服务器对与所述其他互斥锁标识未锁定成功的情况下,判断是否到达第二预设时间;本地标识锁定单元控制单元,用于当所述计时判断单元的判断结果为是时,控制所述本地标识锁定单元将所述资源的位于本地的当前互斥锁标识设置为所述锁定状态。与现有技术相比,本申请包括以下优点:在本申请中,由于为每台可能发生并发访问冲突的服务器分配了互斥锁标识,并且每次在访问某个资源之前,都需要确认其他服务器能够将各自的关于该资源的互斥锁标识成功锁定,如果其他服务器正在访问该资源或者其他服务器出现死机重启等情况,就暂停对所述资源的访问,所以本实施例可以避免对资源并发访问的情况发生。此外,由于本申请中,表示资源是否被锁定的互斥锁标识不再存储在Memcache等第三方系统中,因此,也不再依赖第三方系统的稳定性。本申请中,还可以控制等待其他服务器的反馈信息的时间长度,避免等待时间过长而形成死锁。当然,实施本申请的任一产品并不一定需要同时达到以上所述的所有优点。


为了更清楚地说明本申请实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。图1为本申请的一种分布式系统的资源访问方法实施例1的流程图;图2为本申请的一种分布式系统的资源访问方法实施例2的流程图;图3为本申请的将所述资源的位于本地的当前互斥锁标识设置为所述锁定状态的步骤流程图;图4为本申请的分布式系统中的其他服务器将所述资源相对应的其他互斥锁标识设置为锁定状态的步骤流程图;图5为本申请的分布式系统的资源访问系统实施例1的结构图;图6为本申请的分布式系统的资源访问系统实施例2的结构图;图7为本申请的本地标识锁定单元的结构图;图8为本申请的其他标识锁定请求单元的结构图。
具体实施方式
`下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。本申请可用于众多通用或专用的计算装置环境或配置中。例如:个人计算机、服务器计算机、手持设备或便携式设备、平板型设备、多处理器装置、包括以上任何装置或设备的分布式计算环境等等。本申请可以在由计算机执行的计算机可执行指令的一般上下文中描述,例如程序模块。一般地,程序模块包括执行特定任务或实现特定抽象数据类型的例程、程序、对象、组件、数据结构等等。也可以在分布式计算环境中实践本申请,在这些分布式计算环境中,由通过通信网络而被连接的远程处理设备来执行任务。在分布式计算环境中,程序模块可以位于包括存储设备在内的本地和远程计算机存储介质中。本申请的主要思想之一可以包括,对于某一个可能被并发访问的资源,在对该资源进行访问之前,向所有可能访问该资源的服务器发送请求,通过该请求判断其他服务器是否正在访问该资源,只有在所有其他服务器的反馈信息表示没有访问该资源时,当前服务器才对该资源进行访问。具体的,本申请中,所述分布式系统中的各台服务器具有与所述资源一一对应的互斥锁标识,所述互斥锁标识具有锁定状态与未锁定状态。当所述互斥锁标识处于锁定状态时,具有所述互斥锁标识的服务器就不能够再访问所述资源。并且,所述互斥锁标识处于锁定状态后,不能被再次锁定。因此所述互斥锁标识可以保证在同一时刻,只有一个进程访问所述资源。图1为本申请的一种分布式系统的资源访问方法实施例1的流程图。如图1所示,该方法可以包括以下步骤:SlOl:在访问所述资源之前,当前服务器将所述资源的位于本地的当前互斥锁标识设置为所述锁定状态;S102:所述当前服务器请求所述分布式系统中的其他服务器将所述资源相对应的其他互斥锁标识设置为锁定状态;当前服务器向其他可能存在并发访问的服务器发送请求,请求其他服务器将其他服务器关于该资源的互斥锁标识设置为锁定状态。其他服务器接收到这个请求,会尝试将自身的关于该资源的互斥锁进行锁定。如果锁定成功,其他服务器可以向当前服务器返回表示锁定成功的反馈信息。S103:所述当前服务器判断所述分布式系统中的其他服务器对所述其他互斥锁标识是否锁定成功;如果是,执行步骤S104 ;否则,停止。步骤S103中,可以通过判断是否接收到所有的其他服务器返回的表示锁定成功的反馈信息,来判断所述分布式系统中的其他服务器对所述其他互斥锁标识是否锁定成功。其他服务器没有返回表示锁定成功的反馈信息时,可能存在多种情况。一种情况是某台服务器,例如服务器A,正在访问该资源;而服务器A在访问该资源之前,已经将自身以及其他服务器的关于该资源的互斥锁标识进行了锁定,所以其他服务器就无法再次对该互斥锁标识进行锁定。另 一种情况是,某台服务器,例如服务器B,由于某种原因进行了重启,则在重启过程中,该服务器B就无法返回表示锁定成功的反馈信息。S104:所述当前服务器访问所述资源。可见,本申请中由于为每台可能发生并发访问冲突的服务器分配了互斥锁标识,并且每次在访问某个资源之前,都需要确认其他服务器能够将各自的关于该资源的互斥锁标识成功锁定,如果其他服务器正在访问该资源或者其他服务器出现死机重启等情况,就暂停对所述资源的访问,所以本实施例可以避免对资源并发访问的情况发生。此外,由于本申请中,表示资源是否被锁定的互斥锁标识不再存储在Memcache等第三方系统中,因此,也不再依赖第三方系统的稳定性。图2为本申请的一种分布式系统的资源访问方法实施例2的流程图。如图2所示,该方法可以包括以下步骤:S201:在访问所述资源之前,当前服务器将所述资源的位于本地的当前互斥锁标识设置为所述锁定状态;S202:所述当前服务器请求所述分布式系统中的其他服务器将所述资源相对应的其他互斥锁标识设置为锁定状态;S203:判断是否在第一预设时间内接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信息;如果是,执行步骤S204 ;否则,停止。S204:所述当前服务器访问所述资源。本实施例中,判断是否接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信息时,增加了关于时间的判断,如果在第一预设时间内没有接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信息,则不再等待其他服务器的反馈信息,认为有其他服务器在访问该资源,从而当前服务器暂停访问该资源。可见,本实施例中的分布式系统的资源访问方法,可以控制等待其他服务器的反馈信息的时间长度,避免等待时间过长而形成死锁。图3为本申请的将所述资源的位于本地的当前互斥锁标识设置为所述锁定状态的步骤流程图。如图3所示,该流程可以包括步骤:S301:查找所述资源的资源标识;所述资源标识与所述资源一一对应;具体的,可以为每个资源分配一个唯一的ID作为所述资源的资源标识。S302:根据预先设定的资源标识与互斥锁标识之间的映射关系,确定所述资源的位于本地的当前互斥锁标识;所述资源标识与所述互斥锁标识之间具有映射关系。具体的,该关系可以保存在资源ID与互斥锁标识的映射表中。在需要确定资源对应的互斥锁标识时,可以从该映射表中进行查找。S303:将所述当前互斥锁标识设置为所述锁定状态。图4为本申请的分布式系统中的其他服务器将所述资源相对应的其他互斥锁标识设置为锁定状态的步骤流程图。如图4所示,该流程可以包括步骤:S401:从预先保存的并发访问控制列表中读取需要设置互斥锁标识状态的服务器地址信息;所述并发访问控制列表中存储有存在并发访问冲突的服务器地址信息;具体的,并发访问控制列表中,可以存储存在并发访问冲突的可能性的服务器地址信息。对于资源X,可能存在并发访问冲突的服务器可能为A、B、C ;对于资源Y,可能存在并发访问冲突的服务器可能为B、C、D。也就是说,并发访问控制列表中,对于某一资源,可以不必存储分布式系统中所有服务器的地址信息,而只需要存储有可能对该资源并发访问的服务器的地址信息。S402:根据所述服务器地址信息,向需要设置互斥锁标识状态的服务器发送访问所述资源的请求;S403:需要设置互斥锁标识状态的服务器接收到所述请求后,尝试将本地的所述互斥锁标识设置为锁定状态;当需要设置互斥锁标识状态的服务器将所述互斥锁标识设置为锁定状态后,需要设置互斥锁标识状态的服务器会向发送请求的服务器发送反馈信息,该反馈信息表示互斥锁标识设置成功。S404:接收需要设置互斥锁标识状态的服务器发送的表示设置成功的反馈信息;相应的,所述判断所述分布式系统中的其他服务器与所述资源相对应的所述互斥锁标识是否锁定成功,具体包括:S405:判断是否接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信 肩、O需要说明的是,为了让所述当前服务器在无法接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信息时,能够等待一定时间后重新尝试访问该资源,上述实施例中,在分布式系统中的其他服务器对与所述其他互斥锁标识未锁定成功的情况下,所述方法还可以包括步骤:所述当前服务器判断是否到达第二预设时间,如果是,则执行所述当前服务器将所述资源的位于本地的当前互斥锁标识设置为所述锁定状态的步骤。对于前述的各方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本申请并不受所描述的动作顺序的限制,因为依据本申请,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于优选实施例,所涉及的动作和模块并不一定是本申请所必须的。本申请还提供了一种分布式系统的资源访问系统。所述分布式系统中的各台服务器具有与所述资源一一对应的互斥锁标识,所述互斥锁标识具有锁定状态与未锁定状态。需要说明的是,本发明中的分布式系统的资源访问系统在实际应用中可以集成到服务器中来实现。图5为本申请的分布式系统的资源访问系统实施例1的结构图。如图5所示,所述资源访问系统包括:本地标识锁定单元501,用于在访问所述资源之前,将所述资源的位于本地的当前互斥锁标识设置为所述锁定状态;其他标识 锁定请求单元502,用于请求所述分布式系统中的其他服务器将所述资源相对应的其他互斥锁标识设置为锁定状态;第一判断单元503,用于判断所述分布式系统中的其他服务器对所述其他互斥锁标识是否锁定成功;访问单元504,用于当所述第一判断单元的判断结果为是时,访问所述资源。本申请的分布式系统的资源访问系统,由于为每台可能发生并发访问冲突的服务器分配了互斥锁标识,并且每次在访问某个资源之前,都需要确认其他服务器能够将各自的关于该资源的互斥锁标识成功锁定,如果其他服务器正在访问该资源或者其他服务器出现死机重启等情况,就暂停对所述资源的访问,所以本实施例可以避免对资源并发访问的情况发生。此外,由于本申请中,表示资源是否被锁定的互斥锁标识不再存储在Memcache等第三方系统中,因此,也不再依赖第三方系统的稳定性。图6为本申请的分布式系统的资源访问系统实施例2的结构图。如图6所示,所述资源访问系统包括:本地标识锁定单元601,用于在访问所述资源之前,将所述资源的位于本地的当前互斥锁标识设置为所述锁定状态;其他标识锁定请求单元602,用于请求所述分布式系统中的其他服务器将所述资源相对应的其他互斥锁标识设置为锁定状态;计时判断子单元603,用于判断是否在第一预设时间内接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信息;访问单元604,用于当所述第一判断单元的判断结果为是时,访问所述资源。本实施例中,通过计时判断子单元判断是否接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信息时,增加了关于时间的判断,如果在第一预设时间内没有接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信息,则不再等待其他服务器的反馈信息,认为有其他服务器在访问该资源,从而当前服务器暂停访问该资源。可见,本实施例中的分布式系统的资源访问系统,可以控制等待其他服务器的反馈信息的时间长度,避免等待时间过长而形成死锁。图7为本申请的本地标识锁定单元的结构图。如图7所示,该本地标识锁定单元可以包括:资源标识查找子单元701,用于查找所述资源的资源标识;所述资源标识与所述资源--对应;
互斥锁标识确定子单元702,用于根据预先设定的资源标识与互斥锁标识之间的映射关系,确定所述资源的位于本地的当前互斥锁标识;互斥锁标识锁定子单元703,用于将所述当前互斥锁标识设置为所述锁定状态。图8为本申请的其他标识锁定请求单元的结构图。如图8所示,该其他标识锁定请求单元可以包括:地址信息读取子单元801,用于从预先保存的并发访问控制列表中读取需要设置互斥锁标识状态的服务器地址信息;所述并发访问控制列表中存储有存在并发访问冲突的服务器地址信息;锁定请求发送子单元802,用于根据所述服务器地址信息,向需要设置互斥锁标识状态的服务器发送访问所述资源的请求;反馈信息接收子单元803,用于接收需要设置互斥锁标识状态的服务器发送的表示设置成功的反馈信息;相应的,所述第一判断单元503,具体可以包括:第一判断子单元,用于判断是否接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信息。需要说明的是,为了让所述当前服务器在无法接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信息时,能够等待一定时间后重新尝试访问该资源,上述实施例中,在分布式系统中的其他服务器对与所述其他互斥锁标识未锁定成功的情况下,所述系统还可以包括:计时判断单元,用于在分布式系统中的其他服务器对与所述其他互斥锁标识未锁定成功的情况下,判断是否到达第二预设时间;本地标识锁定单元控制单元,用于当所述计时判断单元的判断结果为是时,控制所述本地标识锁定单元将所述资源的位于本地的当前互斥锁标识设置为所述锁定状态。需要说明的是,本说明书中的各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似的部分互相参见即可。对于系统类实施例而言,由于其与方法实施例基本相似,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个......”限定的要素,
并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。为了描述的方便,描述以上系统时以功能分为各种单元分别描述。当然,在实施本申请时可以把各单元的功能在同一个或多个软件和/或硬件中实现。通过以上的实施方式的描述可知,本领域的技术人员可以清楚地了解到本申请可借助软件加必需的通用硬件平台的方式来实现。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品可以存储在存储介质中,如R0M/RAM、磁碟、光盘等,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本申请各个实施例或者实施例的某些部分所述的方法。以上对本申请所提供的一种分布式系统的资源访问方法和系统进行了详细介绍,本文中应用了具体个例对本申请的 原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本申请的方法及其核心思想;同时,对于本领域的一般技术人员,依据本申请的思想,在具体实施方式
及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本申请的限制。
权利要求
1.一种分布式系统的资源访问方法,其特征在于,所述分布式系统中的各台服务器具有与所述资源一一对应的互斥锁标识,所述互斥锁标识具有锁定状态与未锁定状态,所述方法包括: 在访问所述资源之前,当前服务器将所述资源的位于本地的当前互斥锁标识设置为所述锁定状态; 所述当前服务器请求所述分布式系统中的其他服务器将所述资源相对应的其他互斥锁标识设置为锁定状态; 所述当前服务器判断所述分布式系统中的其他服务器对所述其他互斥锁标识是否锁定成功; 如果是,则所述当前服务器访问所述资源。
2.根据权利要求1所述的方法,其特征在于,所述将所述资源的位于本地的当前互斥锁标识设置为所述锁定状态,包括: 查找所述资源的资源标识;所述资源标识与所述资源一一对应; 根据预先设定的资源标识与互斥锁标识之间的映射关系,确定所述资源的位于本地的当前互斥锁标识; 将所述当前互斥锁标识设置为所述锁定状态。
3.根据权利要求1所述的方法,其特征在于,所述当前服务器请求分布式系统中的其他服务器将所述资源相对应的其他互斥锁标识设置为锁定状态,包括: 所述当前服务器从预先保·存的并发访问控制列表中读取需要设置互斥锁标识状态的服务器地址信息;所述并发访问控制列表中存储有存在并发访问冲突的服务器地址信息; 根据所述服务器地址信息,所述当前服务器向需要设置互斥锁标识状态的服务器发送访问所述资源的请求,以便所述需要设置互斥锁标识状态的服务器接收到所述请求后,尝试将本地的所述互斥锁标识设置为锁定状态; 所述当前服务器接收所述需要设置互斥锁标识状态的服务器发送的表示设置成功的反馈信息; 则所述判断所述分布式系统中的其他服务器与所述资源相对应的所述互斥锁标识是否锁定成功,具体包括: 判断是否接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信息。
4.根据权利要求3所述的方法,其特征在于,所述判断是否接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信息,具体包括: 判断是否在第一预设时间内接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信息。
5.根据权利要求1所述的方法,其特征在于,在分布式系统中的其他服务器对与所述其他互斥锁标识未锁定成功的情况下,所述方法还包括: 所述当前服务器判断是否到达第二预设时间,如果是,则执行所述当前服务器将所述资源的位于本地的当前互斥锁标识设置为所述锁定状态的步骤。
6.一种分布式系统的资源访问系统,其特征在于,所述分布式系统中的各台服务器具有与所述资源一一对应的互斥锁标识,所述互斥锁标识具有锁定状态与未锁定状态,所述资源访问系统包括:本地标识锁定单元,用于在访问所述资源之前,将所述资源的位于本地的当前互斥锁标识设置为所述锁定状态; 其他标识锁定请求单元,用于请求所述分布式系统中的其他服务器将所述资源相对应的其他互斥锁标识设置为锁定状态; 第一判断单元,用于判断所述分布式系统中的其他服务器对所述其他互斥锁标识是否锁定成功; 访问单元,用于当所述第一判断单元的判断结果为是时,访问所述资源。
7.根据权利要求6所述的系统,其特征在于,所述本地标识锁定单元,包括: 资源标识查找子单元,用于查找所述资源的资源标识;所述资源标识与所述资源一一对应; 互斥锁标识确定子单元,用于根据预先设定的资源标识与互斥锁标识之间的映射关系,确定所述资源的位于本地的当前互斥锁标识; 互斥锁标识锁定子单元,用于将所述当前互斥锁标识设置为所述锁定状态。
8.根据权利要求6所述的系统,其特征在于,所述其他标识锁定请求单元,包括: 地址信息读取子单元,用于从预先保存的并发访问控制列表中读取需要设置互斥锁标识状态的服务器地址信息;所述并发访问控制列表中存储有存在并发访问冲突的服务器地址信息; 锁定请求发送 子单元,用于根据所述服务器地址信息,向需要设置互斥锁标识状态的服务器发送访问所述资源的请求; 反馈信息接收子单元,用于接收所述需要设置互斥锁标识状态的服务器发送的表示设置成功的反馈信息;以便所述需要设置互斥锁标识状态的服务器接收到所述请求后,尝试将本地的所述互斥锁标识设置为锁定状态; 所述第一判断单元,具体包括: 第一判断子单元,用于判断是否接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信息。
9.根据权利要求8所述的系统,其特征在于,所述第一判断子单元具体包括: 计时判断子单元,用于判断是否在第一预设时间内接收到全部所述需要设置互斥锁标识状态的服务器的所述反馈信息。
10.根据权利要求6所述的系统,其特征在于,还包括: 计时判断单元,用于在分布式系统中的其他服务器对与所述其他互斥锁标识未锁定成功的情况下,判断是否到达第二预设时间; 本地标识锁定单元控制单元,用于当所述计时判断单元的判断结果为是时,控制所述本地标识锁定单元将所述资源的位于本地的当前互斥锁标识设置为所述锁定状态。
全文摘要
本申请提供了一种分布式系统的资源访问方法和系统,所述方法包括在访问所述资源之前,当前服务器将所述资源的位于本地的当前互斥锁标识设置为所述锁定状态;所述当前服务器请求所述分布式系统中的其他服务器将所述资源相对应的其他互斥锁标识设置为锁定状态;所述当前服务器判断所述分布式系统中的其他服务器对所述其他互斥锁标识是否锁定成功;如果是,则所述当前服务器访问所述资源。采用本申请的方法及系统可以避免对资源并发访问的情况发生。
文档编号H04L29/08GK103248667SQ20121003305
公开日2013年8月14日 申请日期2012年2月14日 优先权日2012年2月14日
发明者佘智勇 申请人:阿里巴巴集团控股有限公司
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1