本申请涉及在故障恢复期间增加数据库的可用性。在此描述的实施例旨在在数据库重新配置期间提供数据库访问并在数据库重新配置期间维护复制连接。在一个实施例中,计算机系统建立多个法定数量拷贝集以复制数据分区的数据。法定数量拷贝集确保了至少最小数目的拷贝可用于在分区重新配置期间提交待决事务。计算机系统确定数据分区重新配置已经开始,并且使用法定数量拷贝集中的每一个中的至少法定数量个拷贝来在数据分区的重新配置期间提供对数据分区的数据的访问。
【技术实现步骤摘要】
在故障恢复期间增加数据库的可用性
本申请涉及在故障恢复期间增加数据库的可用性。特别是,在数据分区的重新配置期间提供对数据分区的数据的访问。
技术介绍
计算机已变得高度集成于工作、家庭、移动设备以及许多其他地方中。计算机可快速且有效地处理大量信息。被设计成在计算机系统上运行的软件应用允许用户执行包括商业应用、学校作业、娱乐等等在内的各种各样的功能。软件应用通常被设计成执行特定任务,诸如用于草拟文档的文字处理器应用或者用于发送、接收和组织电子邮件的电子邮件程序。在许多情况下,软件应用程序被设计为与其他软件应用程序或其他计算机系统交互。例如,因特网浏览器将用户请求发送给web服务器,并且,这些web服务器通过对用户的请求进行响应来应答。web服务器和其它计算机系统可以被配置为访问数据存储以作为对用户请求的响应的一部分。这些数据存储可以存储有大量的信息,并且可包括复制数据以用于附加的冗余性的拷贝。在一些情况下,这些拷贝被分组在一起作为拷贝集或群集。当拷贝集中的一个拷贝变得不可用且随后恢复在线时,拷贝集必须被更新并重新配置。在这种重新配置期间,拷贝集不可用于对数据读或写请求进行响应。
技术实现思路
在此描述的实施例旨在在数据库重新配置期间提供数据库访问并在数据库重新配置期间维护复制连接。在一个实施例中,计算机系统建立多个法定数量拷贝集以复制数据分区的数据。法定数量拷贝集确保了至少最小数目的拷贝可用于在分区重新配置期间提交待决事务。计算机系统确定数据分区重新配置已经启动,并且使用在法定数量拷贝集中的每一个中的至少法定数量个拷贝来在数据分区的重新配置期间提供对数据分区的数据的访问。在另一个实施例中,计算机系统建立多个法定数量拷贝集以复制数据分区的数据。法定数量拷贝集确保了至少最小数目的拷贝可用于在分区重新配置期间提交待决事务。计算机系统确定拷贝的离开已经启动数据分区的重新配置。计算机系统防止现有的数据库复制连接在拷贝离开时就断开,并且使用数据分区重新配置期间所维护的法定数量拷贝集中的每一个中的至少法定数量个拷贝来在重新配置期间提供对数据分区的数据的访问。提供本概述以便以简化形式介绍在以下详细描述中进一步描述的一些概念。本
技术实现思路
并非旨在标识所要求保护的主题的关键特征或必要特征,也不旨在用于帮助确定所要求保护的主题的范围。另外的特征和优点将在以下的描述中阐述,并且部分可从该描述中显而易见,或者可以从此处的教示实践中习得。本专利技术的各特征和优点可以通过在所附的权利要求书中特别指出的手段和组合来实现和获得。本专利技术的特征将从以下描述和所附权利要求书中变得完全显而易见,或者可通过如下所述对本专利技术的实践而获知。附图说明为了进一步阐明本专利技术的各实施例的以上和其他优点和特征,将参考附图来呈现本专利技术的各实施例的更具体的描述。可以理解,这些附图只描绘本专利技术的典型实施例,因此将不被认为是对其范围的限制。本专利技术将通过使用附图用附加特征和细节来描述和解释, 附图中图1示出本专利技术的实施例可以在其中操作的计算机体系结构,所述操作包括在数据库重新配置期间提供数据库访问以及在数据库重新配置期间维护复制连接。图2示出用于在数据库重新配置期间提供数据库访问的示例方法的流程图。图3示出用于在数据库重新配置期间维护复制连接的示例方法的流程图。图4示出重新配置过程的流程图。具体实施方式在此描述的实施例旨在在数据库重新配置期间提供数据库访问并在数据库重新配置期间维护复制连接。在一个实施例中,计算机系统建立多个法定数量(quorum)拷贝集以复制数据分区的数据。法定数量拷贝集确保了至少最小数目的拷贝可用于在分区重新配置期间提交待决事务。计算机系统确定数据分区重新配置已经开始,并且使用在法定数量拷贝集中的每一个中的至少法定数量个拷贝来在数据分区的重新配置期间提供对数据分区的数据的访问。在另一个实施例中,计算机系统建立多个法定数量拷贝集以复制数据分区的数据。法定数量拷贝集确保了至少最小数目的拷贝可用于在分区重新配置期间提交待决事务。计算机系统确定拷贝的离开已经启动数据分区的重新配置。计算机系统防止现有的数据库复制连接在拷贝离开时就断开,并且使用法定数量拷贝集中的每一个中的至少法定数量个拷贝来在数据分区的重新配置期间提供对数据分区的数据的访问。以下讨论现涉及可以执行的多种方法以及方法动作。应当注意,虽然这些方法动作可能是按一定次序讨论的,或者是在流程图中被描绘为是按照特定顺序进行的,然而并非必然需要特定的次序,除非特别声明,或者是因为一个动作依赖于另一动作在该动作被执行之前完成而需要的。本专利技术的各实施例可包括或利用专用或通用计算机,该专用或通用计算机包括诸如例如一个或多个处理器和系统存储器等计算机硬件,如以下更详细讨论的。本专利技术范围内的各实施例还包括用于携带或存储计算机可执行指令和/或数据结构的物理介质和其他计算机可读介质。这些计算机可读介质可以是通用或专用计算机系统能够访问的任何可用介质。存储计算机可执行指令的计算机可读介质是计算机存储介质。携带计算机可执行指令的计算机可读介质是传输介质。由此,作为示例而非限制,本专利技术的各实施例可包括至少两种完全不同类型的计算机可读介质计算机存储介质和传输介质。计算机存储介质包括RAM、ROM、EEPROM、CD-ROM或其他光盘存储、磁盘存储或其他磁存储设备、或可用于存储计算机可执行指令或数据结构形式的所需程序代码装置且可由通用或专用计算机访问的任何其他介质。“网络”被定义为允许在计算机系统和/或模块和/或其他电子设备之间传输电子数据的一个或多个数据链路。当信息通过网络或另一个通信连接(硬连线、无线、或者硬连线或无线的组合)传输或提供给计算机时,该计算机将该连接适当地视为传输介质。传输介质可包括可用于携带计算机可执行指令或数据结构形式的所需程序代码装置且可由通用或专用计算机访问的网络和/或数据链路。上述的组合也应被包括在计算机可读介质的范围内。此外,在到达各种计算机系统组件之后,计算机可执行指令或数据结构形式的程序代码装置可从传输介质自动传输到计算机存储介质(或反之亦然)。例如,通过网络或数据链路接收到的计算机可执行指令或数据结构可被缓存在网络接口模块(例如,“mc”) 内的RAM中,然后最终被传输到计算机系统RAM和/或计算机系统处的较不易失性的计算机存储介质。因而,应当理解,计算机存储介质可被包括在还利用(或甚至主要利用)传输介质的计算机系统组件中。计算机可执行指令包括,例如使通用计算机、专用计算机、或专用处理设备执行某一功能或某组功能的指令和数据。计算机可执行指令可以是例如二进制代码、诸如汇编语言之类的中间格式指令、或甚至源代码。尽管用结构特征和/或方法动作专用的语言描述了本主题,但可以理解,所附权利要求书中定义的主题不必限于上述特征或动作。相反,上述特征和动作是作为实现权利要求的示例形式而公开的。本领域的技术人员将理解,本专利技术可以在具有许多类型的计算机系统配置的网络计算环境中实践,这些计算机系统配置包括个人计算机、台式计算机、膝上型计算机、消息处理器、手持式设备、多处理器系统、基于微处理器的或可编程消费电子设备、网络PC、小型计算机、大型计算机、移动电话、PDA、寻呼机、路由器、交换机等等。本专利技术也可在其中通过网络本文档来自技高网...
【技术保护点】
【技术特征摘要】
2010.11.17 US 12/948,5411.一种在包括多个计算系统的计算机联网环境中,在包括处理器和存储器的计算机系统中的用于在数据库重新配置期间提供数据库访问的计算机实现的方法,所述方法包括建立多个法定数量拷贝集(126A/U6B)来复制给定数据分区的数据的动作,其中所述法定数量拷贝集确保了至少最小数目的拷贝用于在分区重新配置(120)期间提交待决事务的动作;确定数据分区的重新配置已经启动的动作;以及在所述数据分区的重新配置(120)期间使用所述法定数量拷贝集(U6A)中的每一个中的至少法定数量个拷贝(127A-128A2)来提供对所述数据分区的数据的访问的动作。2.如权利要求1所述的方法,其特征在于,每个拷贝集包括多个次要拷贝。3.如权利要求2所述的方法,其特征在于,所述多个法定数量拷贝集中的至少一个是被实例化为在重新配置期间对请求进行应答的临时法定数量拷贝集。4.如权利要求3所述的方法,其特征在于,在重新配置已经结束之后,移除所述临时法定数量拷贝集。5.如权利要求1所述的方法,其特征在于,在重新配置的多个阶段期间提供对所述数据库分区的访问。6.如权利要求1所述的方法,其特征在于,由所述多个法定数量拷贝集中的拷贝离开或加入拷贝集来启动重新配置。7.如权利要求6所述的方法,其特征在于,进一步包括防止现有的数据库复制连接由于拷贝的离开而被断开。8.一种用于实现一种方法的计算机程序产品,所述方法用于在数据库重新配置期间维护复制连接,所述计算机程序产品包括其上存储有计算机可执行指令的一个或多个计算机可读存储介质,所述指令在被计算系统的一个或多个处理器执行时使得所述计算系统执行所述方法,所述方法包括建立多个法定数量拷贝集...
【专利技术属性】
技术研发人员:V·沙阿,S·O·沃蒂莱宁,T·塔留斯,
申请(专利权)人:微软公司,
类型:发明
国别省市:
还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。