CN111444147A - 一种数据页创建方法、装置、终端设备及存储介质 - Google Patents
一种数据页创建方法、装置、终端设备及存储介质 Download PDFInfo
- Publication number
- CN111444147A CN111444147A CN202010238596.4A CN202010238596A CN111444147A CN 111444147 A CN111444147 A CN 111444147A CN 202010238596 A CN202010238596 A CN 202010238596A CN 111444147 A CN111444147 A CN 111444147A
- Authority
- CN
- China
- Prior art keywords
- data page
- database
- disk
- log
- serial number
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/10—File systems; File servers
- G06F16/16—File or folder operations, e.g. details of user interfaces specifically adapted to file systems
- G06F16/164—File meta data generation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/10—File systems; File servers
- G06F16/11—File system administration, e.g. details of archiving or snapshots
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/10—File systems; File servers
- G06F16/18—File system types
- G06F16/1805—Append-only file systems, e.g. using logs or journals to store data
- G06F16/1815—Journaling file systems
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Data Mining & Analysis (AREA)
- Databases & Information Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Human Computer Interaction (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Storage Device Security (AREA)
Abstract
本发明公开了一种数据页创建方法、装置、终端设备及存储介质。方法包括:接收数据库节点的节点闩锁请求,节点闩锁请求为创建第一数据页的请求;若本地不存在第一数据页的闩锁权限,则向第一数据库发送本地闩锁请求,本地闩锁请求用于向第一数据库请求第一数据页的闩锁权限;接收第一数据库发送的对应本地闩锁请求的闩锁授权信息;基于闩锁授权信息,创建第一数据页并生成控制日志,控制日志用于指示其余磁盘日志序列号集,其余磁盘日志序列号集包括除数据库节点外的其余节点写入磁盘中的第二数据页的日志序列号。利用该方法消除了从磁盘读取数据页或从远程节点读取数据页的操作,减少了创建数据页的代价,提升了数据库管理系统的整体执行效率。
Description
技术领域
本发明实施例涉及数据库技术领域,尤其涉及一种数据页创建方法、装置、终端设备及存储介质。
背景技术
数据页(PAGE)作为数据库管理系统中数据存储的基本单位,是数据访问、修改、以及I/O的基本单位。数据库一般会分配一片连续的内存用于数据页缓存,以提高数据访问性能,所有数据的访问、修改都是针对缓存中的数据页。
数据页创建是数据页修改的一种特殊形态,所有数据页第一次分配使用时,都要求先创建数据页,进行数据页的格式化,再进行后续的数据页修改操作。另外一种创建数据页的场景是,已分配使用的数据页释放回文件系统后,再次使用之前,也需要进行数据页创建操作。
共享存储集群中创建数据页前必须获取数据页的最新日志序列号(LOG SEQUENCENUMBER,LSN)值,并进行节点间LSN同步,以确保故障重启后,数据的正确性。若按照最新数据页分布情况分析,则某个节点创建数据页需要从磁盘加载数据页或从远程节点读取数据页,以确保创建数据页动作产生的重做日志的日志序列号是递增的,从而使得创建数据页操作繁琐。
发明内容
为解决上述技术问题,本发明提供了一种数据页创建方法、装置、终端设备及存储介质,减少了创建数据页的代价。
第一方面,本发明实施例提供了一种数据页创建方法,包括:
接收数据库节点的节点闩锁请求,所述节点闩锁请求为创建第一数据页的请求;
若本地不存在所述第一数据页的闩锁权限,则向第一数据库发送本地闩锁请求,所述本地闩锁请求用于向所述第一数据库请求所述第一数据页的闩锁权限;
接收所述第一数据库发送的对应所述本地闩锁请求的闩锁授权信息;
基于所述闩锁授权信息,创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的第二数据页的日志序列号。
进一步地,所述本地闩锁请求包括所述数据库节点的第一磁盘日志序列号集,所述第一磁盘日志序列号集包括所述数据库节点发送所述本地闩锁请求时写入磁盘中的第三数据页的日志序列号;所述闩锁授权信息包括:授权指示信息和全局磁盘日志序列号集,所述全局磁盘日志序列号集基于所述第一磁盘日志序列号集和所述其余磁盘日志序列号集更新确定,所述全局磁盘日志序列号集用于生成控制日志,所述全局磁盘日志序列号集包括目标数据库节点写入磁盘中的第四数据页的日志序列号,所述目标数据库节点为存在数据页修改的数据库节点。
进一步地,所述基于所述闩锁授权信息,创建第一数据页并生成控制日志,包括:
基于所述全局磁盘日志序列号集中其余磁盘日志序列号集更新本地磁盘日志序列号集;
基于所述其余磁盘日志序列号集,生成控制日志;
基于所述授权指示信息执行闩封锁,并创建第一数据页,生成对应的重做日志。
进一步地,该方法还包括:
获取第一数据库发送的第一权限回收请求;
在对应所述第一权限回收请求的闩锁权限被释放时,向所述第一数据库发送第一响应信息,所述第一响应信息包括所述数据库节点的第二磁盘日志序列号集,所述第二磁盘日志序列号集包括所述数据库节点发送第一响应信息时写入磁盘中的第五数据页的日志序列号。
第二方面,本发明实施例提供了一种数据页创建方法,包括:
获取第二数据库的本地闩锁请求,所述本地闩锁请求用于向第一数据库请求第一数据页的闩锁权限;
基于所述本地闩锁请求,确定对应的闩锁授权信息;
将所述闩锁授权信息发送至所述第二数据库,以供所述第二数据库基于所述闩锁授权信息创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的所述第二数据页对应的日志序列号。
进一步地,所述本地闩锁请求包括所述数据库节点的第一磁盘日志序列号集,所述第一磁盘日志序列号集包括所述数据库节点发送所述本地闩锁请求时写入磁盘中的第三数据页的日志序列号;所述闩锁授权信息包括:授权指示信息和全局磁盘日志序列号集,所述全局磁盘日志序列号集基于所述第一磁盘日志序列号集和所述其余磁盘日志序列号集更新确定,所述全局磁盘日志序列号集用于生成控制日志,所述全局磁盘日志序列号集包括目标数据库节点写入磁盘中的第四数据页的日志序列号,所述目标数据库节点为存在数据页修改的数据库节点。
进一步地,该方法还包括:
根据所述第一磁盘日志序列号集更新所述全局磁盘日志序列号集。
进一步地,所述基于所述本地闩锁请求,确定对应的闩锁授权信息,包括:
基于所述本地闩锁请求判断是否存在冲突数据库,所述冲突数据库已获得所述第一数据页的闩锁权限;
基于判断结果,确定全局磁盘日志序列号集;
基于所述全局磁盘日志序列号集和授权指示信息,确定闩锁授权信息。
进一步地,所述基于判断结果,确定全局磁盘日志序列号集,包括:
若判断结果为存在冲突数据库,则向所述冲突数据库发送第二权限回收请求;
接收所述第二权限回收请求对应的第二响应信息,所述第二响应信息包括所述冲突数据库的第三磁盘日志序列号集,所述第三磁盘日志序列号集为所述冲突数据库写入磁盘中的第六数据页的日志序列号;
基于所述第三磁盘日志序列号集更新所述全局磁盘日志序列号集。
进一步地,所述基于判断结果,确定全局磁盘日志序列号集,包括:
若判断结果为不存在冲突数据库,则获取全局磁盘日志序列号集。
第三方面,本发明提供了一种数据页创建装置,包括:
第一接收模块,用于接收数据库节点的节点闩锁请求,所述节点闩锁请求为创建第一数据页的请求;
发送模块,用于若本地不存在所述第一数据页的闩锁权限,则向第一数据库发送本地闩锁请求,所述本地闩锁请求用于向所述第一数据库请求所述第一数据页的闩锁权限;
第二接收模块,用于接收所述第一数据库发送的对应所述本地闩锁请求的闩锁授权信息;
创建模块,用于基于所述闩锁授权信息,创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的第二数据页的日志序列号。
第四方面,本发明提供了一种数据页创建装置,包括:
获取模块,用于获取第二数据库的本地闩锁请求,所述本地闩锁请求用于向第一数据库请求第一数据页的闩锁权限;
确定模块,用于基于所述本地闩锁请求,确定对应的闩锁授权信息;
发送模块,用于将所述闩锁授权信息发送至所述第二数据库,以供所述第二数据库基于所述闩锁授权信息创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的所述第二数据页对应的日志序列号。
第五方面,本发明实施例提供了一种终端设备,包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序;
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如本发明第一方面所述的方法。
第六方面,本发明实施例提供了一种终端设备,包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序;
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如本发明第二方面所述的方法。
第七方面,本发明实施例提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现本发明实施例所述的方法。
本发明实施例提供了一种数据页创建方法、装置、终端设备及存储介质,该技术方案,首先接收数据库节点的节点闩锁请求,所述节点闩锁请求为创建第一数据页的请求;其次若本地不存在所述第一数据页的闩锁权限,则向第一数据库发送本地闩锁请求,所述本地闩锁请求用于向所述第一数据库请求所述第一数据页的闩锁权限;然后接收所述第一数据库发送的对应所述本地闩锁请求的闩锁授权信息;最后基于所述闩锁授权信息,创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的第二数据页的日志序列号。利用该技术方案,消除了从磁盘读取数据页或从远程节点读取数据页的操作,减少了创建数据页的代价,提升了数据库管理系统的整体执行效率。
附图说明
图1为本发明实施例一提供的一种数据页创建方法的流程示意图;
图2为本发明实施例二提供的一种数据页创建方法的流程示意图;
图3为本发明实施例三提供的一种数据页创建方法的流程示意图;
图4为本发明实施例四提供的一种数据页创建方法的流程示意图;
图5为本发明实施例五提供的一种数据页创建装置的结构示意图;
图6为本发明实施例六提供的一种数据页创建装置的结构示意图;
图7为本发明实施例七提供的终端设备的结构示意图;
图8为本发明实施例八提供的终端设备的结构示意图。
具体实施方式
下面结合附图和实施例对本发明作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释本发明,而非对本发明的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与本发明相关的部分而非全部结构。
在更加详细地讨论示例性实施例之前应当提到的是,一些示例性实施例被描述成作为流程图描绘的处理或方法。虽然流程图将各项操作(或步骤)描述成顺序的处理,但是其中的许多操作可以被并行地、并发地或者同时实施。此外,各项操作的顺序可以被重新安排。当其操作完成时所述处理可以被终止,但是还可以具有未包括在附图中的附加步骤。所述处理可以对应于方法、函数、规程、子例程、子程序等等。此外,在不冲突的情况下,本发明中的实施例及实施例中的特征可以相互组合。
本发明使用的术语“包括”及其变形是开放性包括,即“包括但不限于”。术语“基于”是“至少部分地基于”。术语“一个实施例”表示“至少一个实施例”。
实施例一
图1为本发明实施例一提供的一种数据页创建方法的流程示意图,该方法可适用于创建数据页的情况。具体的,适用于减少创建数据页创建代价的情况。该方法可以由数据页创建装置执行,该装置可以由软件和/或硬件实现,并一般集成在终端设备上。本实施例中的终端设备可以为手机、个人数字助理、电脑和服务器等设备。
本实施例可以适用于共享存储数据库集群环境。共享存储集群的重做(即REDO)日志管理方式是每个节点(即数据库节点)独立维护一套本地的日志管理系统,当多个节点修改同一个数据页时,进行节点间LSN同步,确保修改同一个数据页产生的LSN值始终是递增的。采用这种实现策略,在系统故障重启时,只要严格按照LSN的递增顺序重做REDO日志,就可以将数据恢复到故障前状态。
闩(LATCH)用于数据页的并发控制,确保用户能正确访问数据页。闩的封锁类型包括S和X两种,其中S是共享锁,X是独占锁,读取数据页之前会S封锁数据页,确保读取数据的过程中,这个数据页不会被修改,在修改数据页之前会X封锁数据页,阻止其他用户访问、修改这个数据页。单节点数据库环境中,缓存中的数据始终是最新的,用户只要通过闩封锁数据页后,就可以在缓存中读取到最新的数据页内容。
共享存储数据库集群环境下同一个数据页可能分布在不同节点的缓存中,并且不保证各节点缓存中数据页内容是完全相同的,最新数据只保存在某些节点缓存中,其他节点缓存中保存的是数据页的一个历史版本。因此,当某个节点修改数据页前,需要先将最新数据页获取到本地缓存。
共享存储数据库集群环境使用全局闩服务和本地闩服务来完成对数据页的访问控制。本地闩服务包含所有已获得全局闩服务授予权限的数据页信息,包括数据页地址、数据页LSN信息、闩锁类型信息等。全局闩服务包含所有已经授予的闩锁信息,包括授予闩锁的节点信息、数据页地址、数据页LSN、闩锁类型、最新数据页分布等信息。本地闩服务可以管理已获得授权的闩锁,记录已经获得哪些对象(如数据页)、什么模式的闩锁,以及正在请求闩封锁的对象和模式。全局闩服务可以提供节点间的闩资源管理,记录哪些节点获取了什么模式的闩锁,哪些节点正在请求闩封锁等信息。全局闩服务和本地闩服务可以单独实现,作为一种可选插件。
按照最新数据页分布情况分析,某个节点修改数据页,存在以下几种场景:
1.所有节点缓存中不包含最新数据页,最新数据页在磁盘中,修改数据页前需要从磁盘加载数据页。
2.部分节点缓存中存在最新数据页,需要从包含最新数据页的节点远程读(REMOTE READ)获取数据页。
3.所有节点缓存中的数据页都是最新数据页,无需从其他节点获取数据页。
根据前述的修改数据页LSN必须递增的要求,创建数据页动作产生REDO日志的LSN值也要保证是递增的,否则在系统故障重启时,可能破坏数据的有效性。比如:
1.节点EP0日志系统的当前LSN(当前LSN指下一个将要分配的LSN,记为CUR_LSN)是10000,EP0释放数据页P1生成的REDO日志的LSN值是10000,这个LSN值会写入数据页P1,称为PAGE_LSN。
2.节点EP1日志系统的当前LSN是9000,EP1从文件系统分配数据页P1,如果直接使用节点当前LSN值生成REDO日志,那么EP1创建数据页P1日志对应的LSN是9000。
3.系统故障重启,重做REDO日志时,根据LSN排序后,先重做了EP1创建数据页的REDO日志(LSN为9000),再重做EP0释放数据页P1的REDO日志(LSN为10000),导致数据错误。
因此,共享存储集群中创建数据页前也必须获取数据页的最新LSN值,并进行节点间LSN同步,以确保故障重启后,数据的正确性。如果最新数据页在某些节点的缓存中,并且全局闩服务中包含数据页的LSN信息,可以利用全局/本地闩服务中数据页的LSN信息,进行节点间LSN同步,确保修改同一个数据页的LSN是递增的。比如:
1.节点EP0日志系统的当前LSN是10000,EP0释放数据页P1生成的REDO日志的LSN值是10000。此时EP0的本地闩服务中,P1的闩锁信息是[EP0,P1,X,10000],表示最后修改数据页P1的节点是EP0,EP0当前拥有数据页P1的X闩锁权限,P1的PAGE_LSN是10000。
2.节点EP1日志系统的当前LSN是9000,EP1从文件系统分配数据页P1,创建数据页P1前,会通过本地闩服务向全局闩服务获取P1闩锁权限。
3.全局闩服务接到EP1关于P1的X闩锁请求时,先从EP0回收P1的闩封锁、获取P1的最新LSN信息,并在授予EP1数据页P1 X闩锁权限的同时,附带P1的最新数据页所在节点信息和最新LSN值。
4.EP1收到全局闩服务关于P1的授权,EP1节点P1的闩锁信息是[EP0,P1,X,10000],明确P1的最新数据页位于EP0,并且P1的PAGE_LSN是10000。
5.EP1后续生成创建数据页P1的REDO日志时,使用MAX[CUR_LSN,PAGE_LSN+1]作为日志对应的LSN,因此创建数据页P1操作对应的LSN是10001(MAX[9000,10000+1])。
6.系统故障重启,重做REDO日志时,根据LSN排序后,先重做EP0释放数据页P1的REDO日志(LSN为10000),再重做EP1创建数据页的REDO日志(LSN为10001)。
但是,正如前面最新数据页分布情况所述,如果当前操作节点不包含最新数据页,最新数据页在磁盘中,并且全局闩服务中没有有效LSN信息时,数据页创建操作就会产生一个磁盘IO,先将数据页从磁盘加载到缓存中,读取数据页LSN,并进行节点LSN同步。比如:
1.节点EP0日志系统的当前LSN是10000,EP0释放数据页P1生成的REDO日志的LSN值是10000。数据页P1释放后,由于缓存淘汰等原因,P1被写入磁盘,并且全局闩服务中数据页P1的闩锁信息被清理掉了。
2.节点EP1日志系统的当前LSN是9000,EP1从文件系统分配数据页P1,创建数据页P1前,通过本地闩服务向全局闩服务获取P1闩锁权限。
3.全局闩服务接到EP1关于P1的X闩锁请求时,直接分配P1的闩锁控制单元,并授予EP1数据页P1 X闩锁权限,同时通知P1的最新数据页位于磁盘,P1的PAGE_LSN值未知。
4.EP1收到全局闩服务关于P1的授权,EP1节点P1的闩锁信息是[DISK,P1,X,UNKNOWN],表明P1的最新数据页位于磁盘,并且P1的PAGE LSN值未知。
5.为了获取数据页P1的PAGE_LSN值,EP1需要发起一个磁盘读请求,将数据页P1加载到本地缓存中,再使用MAX[CUR_LSN,PAGE_LSN+1]作为日志对应的LSN,因此创建数据页P1操作对应的LSN是10001(MAX[9000,10000+1])。
6.系统故障重启,重做REDO日志时,根据LSN排序后,先重做EP0释放数据页P1的REDO日志(LSN为10000),再重做EP1创建数据页的REDO日志(LSN为10001)。
为解决上述技术问题,本发明改造共享存储集群闩锁流程,有效地减少了创建数据页的代价。具体的,如图1所示,本发明实施例提供了一种数据页创建方法,包括如下步骤:
S110、接收数据库节点的节点闩锁请求,所述节点闩锁请求为创建第一数据页的请求。
执行本发明实施例提供的数据页创建的终端设备可以提供本地闩服务。数据库节点可以理解为单节点数据库,其提供基本的并发访问控制功能。节点闩锁请求可以认为是数据库节点向第二数据库发送的创建第一数据页的闩锁请求。第二数据库可以管理数据库节点已授权的闩锁,为数据库节点提供本地闩服务。第一数据页可以认为是待创建的数据页。需要注意的是,本发明中的“第一”、“第二”和“第三”等仅用于区分。如第一数据页可以认为是数据库节点待创建的数据页。第二数据页可以认为是其余节点写入磁盘中的数据页。进一步地,第二数据页可以为其余节点写入磁盘中最大的数据页日志序列号,即PAGE_LSN所对应的数据页。其余节点可以认为是共享存储数据库集群中,除本数据库节点外的所有数据库节点。
节点闩锁请求所包括的内容并不作限定,只要能够指示数据库节点需要创建第一数据页即可。示例性的,节点闩锁请求包括待封锁对象和对应的闩封锁模式。其中,待封锁对象可以用于标识第一数据页,闩封锁模式可以理解为对闩锁对象执行的封锁模式。闩封锁模式可以包括共享(即S)模式和独占(即X)模式。其中,共享模式可以允许多个用户同时以只读的方式访问该待封锁对象。独占模式只允许一个用户访问或修改该待封锁对象。
S120、若本地不存在所述第一数据页的闩锁权限,则向第一数据库发送本地闩锁请求,所述本地闩锁请求用于向所述第一数据库请求所述第一数据页的闩锁权限。
在接收到节点闩锁请求后,本步骤可以确定本地是否已经获取第一数据页的闩锁权限。创建第一数据页的闩锁权限可以为独占模式。故本步骤可以基于节点闩锁请求查询本地是否已获得第一数据页的闩锁权限。具体的,本步骤可以基于待封锁对象和闩封锁模式查询本地是否存在该待封锁对象的该闩封锁模式。
若本地不存在第一数据页的闩锁权限,即提供本地闩服务的第二数据库不存在第一数据页的闩锁权限,则向第一数据库发送本地闩锁请求。第一数据库可以为提供全局闩服务的数据库。本地闩服务通过向全局闩服务发送本地闩锁请求,以请求第一数据页的闩锁权限。本地闩锁请求所包括的内容不作限定,示例性的,可以包括待封锁对象、闩封锁模式和数据库节点的标识信息。该标识信息用于唯一标识数据库节点。
若存在第一数据页的闩锁权限,则可以执行S140。
S130、接收所述第一数据库发送的对应所述本地闩锁请求的闩锁授权信息。
闩锁授权信息可以理解为闩锁授权的指示信息。闩锁授权信息可以认为是第一数据库基于本地闩锁请求反馈的信息。闩锁授权信息可以指示第二数据库当前获取了本地闩锁请求对应的待封锁对应的闩封锁模式,如第二数据库获取了第一数据页的闩锁权限。其中,闩锁授权信息包括的内容不作限定,示例性的,闩锁授权信息包括待封锁对象、闩封锁模式、所述第二数据库的标识信息和全局磁盘日志序列号集。该标识信息用于唯一标识第二数据库。全局磁盘日志序列号集可以用于各节点生成控制日志。
向第一数据库发送本地闩锁请求后,本步骤可以接收第一数据库发送的闩锁授权信息,以获取第一数据页的闩锁权限。
S140、基于所述闩锁授权信息,创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的第二数据页的日志序列号。
控制日志可以认为是特殊类型的重做日志,其生成方法可以参见重做日志生成方法。本步骤获取到闩锁授权信息后,可以创建第一数据页,并基于闩锁授权信息生成控制日志。控制日志可以基于其余磁盘日志序列号集生成。故障重启时,可以按照日志序列号的顺序,从小到大依次重做各数据库节点的重做日志,其中控制日志可以确保在故障重启时,其他节点已经重做完成小于且等于控制日志所包括的其余磁盘日志序列号集所包括各日志序列号对应的重做日志。
其中,控制日志的对应的日志序列号的值取本数据库节点将要分配的日志序列号,即CUR_LSN和其余磁盘日志序列号集所包括的各日志序列号加1,即FILE_LSN+1的最大值。其余磁盘日志序列号集可以包括其余节点写入磁盘中的数据页的最大PAGE_LSN和对应的标识信息,该标识信息(即节点号)用于唯一标识各其余节点。其余磁盘日志序列集的存储形式不作限定,示例性的,可以以数组的形式存储。节点号可以作为数组下标,用来记录各节点(如本数据库节点和其余节点)的磁盘日志序列号,即FILE_LSN值。
本发明实施例提供了一种数据页创建方法,该方法首先接收数据库节点的节点闩锁请求,所述节点闩锁请求为创建第一数据页的请求;其次若本地不存在所述第一数据页的闩锁权限,则向第一数据库发送本地闩锁请求,所述本地闩锁请求用于向所述第一数据库请求所述第一数据页的闩锁权限;然后接收所述第一数据库发送的对应所述本地闩锁请求的闩锁授权信息;最后基于所述闩锁授权信息,创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的第二数据页的日志序列号。利用该方法,消除了从磁盘读取数据页或从远程节点读取数据页的操作,减少了数据页创建的代价,提升了数据库管理系统的整体执行效率。
进一步地,在一个实施例中,所述本地闩锁请求包括所述数据库节点的第一磁盘日志序列号集,所述第一磁盘日志序列号集包括所述数据库节点发送所述本地闩锁请求时写入磁盘中的第三数据页的日志序列号;所述闩锁授权信息包括:授权指示信息和全局磁盘日志序列号集,所述全局磁盘日志序列号集基于所述第一磁盘日志序列号集和所述其余磁盘日志序列号集更新确定,所述全局磁盘日志序列号集用于生成控制日志,所述全局磁盘日志序列号集包括目标数据库节点写入磁盘中的第四数据页的日志序列号,所述目标数据库节点为存在数据页修改的数据库节点。
第二数据库向第一数据库发送本地闩锁请求时,本地闩锁请求包括第一磁盘日志序列号集。第三数据页可以理解为数据库节点发送本地闩锁请求时磁盘中最大的数据页日志序列号,即PAGE_LSN所对应的数据页。第一磁盘日志序列号集包括本数据库节点写入磁盘中的第三数据页的日志序列号和本数据库节点的标识信息,该标识信息用于唯一标识本数据库节点。第一磁盘日志序列号集发送至第一数据库可以供第一数据库更新全局磁盘日志序列号集。
授权指示信息可以认为是闩锁授权的指示信息。接收到授权指示信息可以认为获得了闩锁权限。授权指示信息所包括的内容不作限定,可以包括待封锁对象、闩封锁模式、所述第二数据库的标识信息和全局磁盘日志序列号集。所述第二数据库的标识信息用于唯一标识第二数据库。获取到授权指示信息后,数据库节点可以创建第一数据页。
全局磁盘日志序列号集可以包括各节点最新的写入磁盘中最大的数据页日志序列号,从而用于生成控制日志。在本数据库节点生成控制日志时,可以基于其余磁盘日志序列号集生成控制日志。第四数据页可以认为是目标数据库节点磁盘中最大的数据页日志序列号对应的数据页。
实施例二
图2为本发明实施例二提供的一种数据页创建方法的流程示意图,本实施例在上述实施例的基础上进行具体化。在本实施例中,将基于所述闩锁授权信息,创建第一数据页并生成控制日志,具体包括:
基于所述全局磁盘日志序列号集中其余磁盘日志序列号集更新本地磁盘日志序列号集;
基于所述其余磁盘日志序列号集,生成控制日志;
基于所述授权指示信息执行闩封锁,并创建第一数据页,生成对应的重做日志。
本实施例尚未详尽之处请参见上述实施例。
如图2所示,本发明实施例提供的一种数据页创建方法,包括如下步骤:
S210、接收数据库节点的节点闩锁请求,所述节点闩锁请求为创建第一数据页的请求。
S220、若本地不存在所述第一数据页的闩锁权限,则向第一数据库发送本地闩锁请求,所述本地闩锁请求用于向所述第一数据库请求所述第一数据页的闩锁权限。
S230、接收所述第一数据库发送的对应所述本地闩锁请求的闩锁授权信息。
S240、基于所述全局磁盘日志序列号集中其余磁盘日志序列号集更新本地磁盘日志序列号集。
本地磁盘日志序列号集可以认为是本地存储的各节点的磁盘日志序列号集。本地磁盘日志序列号集可以包括各节点的磁盘日志序列号和对应的各节点的标识信息。本地磁盘日志序列号集的存储形式不作限定,可以是数组的形式,以节点号作为数据下标,用于记录各节点的磁盘日志序列号,即FILE_LSN。
获取到全局磁盘日志序列号集后,可以基于其余磁盘日志序列号集更新本地磁盘日志序列号集,即将其余磁盘日志序列号集写入本地磁盘日志序列号集。
数据库节点中当有数据页修改操作时,也可以将相应数据页在磁盘中最大的数据页日志序列号写入本地磁盘日志序列号集中。
S250、基于所述其余磁盘日志序列号集,生成控制日志。
其中,其余磁盘日志序列号集可以为本地磁盘日志序列号集中获取。本步骤可以基于其余磁盘日志序列号集生成控制日志。此处不对生成方式进行限定,可以参见生成重做日志的方式。控制日志中存储了最新的日志序列号,即其余磁盘日志序列号集,无需从磁盘加载数据页,也无需从远程节点读取数据页,节省了创建数据页的操作。
S260、基于所述授权指示信息执行闩封锁,并创建第一数据页,生成对应的重做日志。
获取授权指示信息后,可以基于授权指示信息执行相应操作对应的闩封锁。闩封锁后可以创建第一数据页,然后生成创建第一数据页对应的重做日志。
以下对本发明实施例进行示例性的描述:
一般的,现有数据库管理系统中REDO日志是处理系统故障恢复的重要手段。REDO日志记录了修改数据页的操作,数据库实例(即数据库节点)修改数据页的同时会生成对应的REDO日志。因此,数据页修改完成后不需要立即将数据页刷入磁盘,只需要将REDO日志刷入磁盘,就可以确保数据不丢失。当数据库实例故障重启时,按照REDO日志的产生顺序(一般通过LSN标识)依次重做REDO日志,就能将所有数据页恢复到故障前的状态。
本发明提供的数据页创建方法可以认为是一种共享集群数据页创建的优化方法,该方法减少了从磁盘读取数据页的步骤。
本发明通过改造共享存储集群闩锁流程,利用本地闩服务向全局闩服务同步当前节点FILE_LSN(FILE_LSN为已写入磁盘的数据页的最大PAGE_LSN)值,即数据库节点的第一磁盘日志序列号集,在数据页创建获取闩锁的同时获取其他节点的FILE_LSN值,即其余磁盘日志序列号集,并生成一个包含各节点FILE_LSN值(即其余磁盘日志序列号集)的特殊类型REDO日志(APPLY LSN WAIT日志)即控制日志,此特殊类型REDO日志对应的LSN值取当前节点(本数据库节点)的CUR_LSN和其他节点FILE_LSN+1的最大值。系统故障重启时,按照LSN排序,从小到大依次重做各节点REDO日志,重做APPLY LSN WAIT日志时,可以确保其他节点已经重做LSN小于等于APPLY LSN WAIT日志中保存的FILE_LSN对应的REDO日志,之后才继续重做该节点REDO日志。通过APPLY LSN WAIT日志实现节点间LSN同步功能,消除了最新数据页位于磁盘时的数据读取操作,减少了数据页创建的代价,提升数据库管理系统的整体执行效率,特别是连续数据插入,引发大量分配数据页操作等操作的执行效率。
数据页创建方法可以包括如下步骤:
(1)向本地闩服务请求数据页的X闩锁请求,即提供本地闩服务的第二数据库接收数据库节点发送的节点闩锁请求。
(2)本地闩服务检查是否已经拥有对应数据页P1的X闩锁权限,如果没有对应数据页P1的X闩锁权限,执行步骤(3),否则执行步骤(5)。
(3)本地闩服务向提供全局闩服务的第一数据库发起P1的X闩锁请求,同时传递当前节点的FILE_LSN值,即第一磁盘日志序列号集,并等待全局闩服务授予P1的X闩锁权限。
(4)本地闩服务收到全局闩服务的X授权,同时收到GBS_POOL的FILE_LSN_ARR数组即全局磁盘日志序列号集,将数组中其他节点的FILE_LSN值记录到LBS_POOL的FILE_LSN_ARR数组即本地磁盘日志序列号集中。
(5)从本地闩服务LBS_POOL的FILE_LSN_ARR数组获取其他节点的FILE_LSN值,生成APPLY LSN WAIT日志,APPLY LSN WAIT日志自身的LSN值取当前节点CUR_LSN和其他节点FILE LSN+1的最大值。
(6)本地闩X封锁,创建数据页,生成对应的REDO日志,释放本地闩X封锁。
本发明实施例提供了一种数据页创建方法,该方法具体化了创建第一数据页和生成控制日志的操作,利用该方法,有效地基于闩锁授权信息创建了控制日志,避免了从磁盘获取数据页或通过远程节点获取数据页,减少了创建数据页的代价,提升了创建数据页的效率。
在上述各实施例的基础上,该方法还包括:
获取第一数据库发送的第一权限回收请求;
在对应所述第一权限回收请求的闩锁权限被释放时,向所述第一数据库发送第一响应信息,所述第一响应信息包括所述数据库节点的第二磁盘日志序列号集,所述第二磁盘日志序列号集包括所述数据库节点发送第一响应信息时写入磁盘中的第五数据页的日志序列号。
在获取闩锁授权信息后,第二数据库还可以获取第一数据库发送的第一权限回收请求。第一权限回收请求可以用于进行闩锁权限的回收。第一权限回收请求所包括的内容不作限定,示例性的,第一权限回收请求可以包括回收对象,回收对象可以为已经获得闩锁授权的待封锁对象。
在本地执行完第一权限回收请求的回收对象的相应操作后,可以释放闩锁权限。若对应第一权限回收请求的闩锁权限被释放,则可以向第一数据库发送第一响应信息。第一响应信息可以为第一权限回收请求的响应信息。第一数据库接收到第一响应信息后可以认为权限回收成功。第五数据页可以认为是数据库节点发送第一响应信息时磁盘中最大的数据页日志序列号对应的数据页。
实施例三
图3为本发明实施例三提供的一种数据页创建方法的流程示意图,该方法可适用于创建数据页的情况。具体的,适用于减少创建页创建代价的情况。该方法可以由数据页创建装置执行,该装置可以由软件和/或硬件实现,并一般集成在终端设备上。本实施例中的终端设备可以为手机、个人数字助理、电脑和服务器等设备。
执行本实施例创建方法的终端设备可以提供全局闩服务。
如图3所示,本发明实施例提供了一种数据页创建方法,包括如下步骤:
S310、获取第二数据库的本地闩锁请求,所述本地闩锁请求用于向第一数据库请求第一数据页的闩锁权限。
第二数据库可以提供本地闩服务。
S320、基于所述本地闩锁请求,确定对应的闩锁授权信息。
获取本地闩锁请求后,可以确定对应所述本地闩锁请求的闩锁授权信息。
具体的,本步骤可以查询针对所述本地闩锁请求是否存在节点封锁冲突,即是否有其余节点已经获取本地闩锁请求所请求的闩锁权限,如通过本地闩锁请求所包括的待封锁对象和闩封锁模式判断。
若存在冲突数据库,则回收相应的闩封锁权限。当闩封锁权限被回收后可以生成闩锁授权信息。若不存在冲突数据库,可以直接确定闩锁授权信息。
S330、将所述闩锁授权信息发送至所述第二数据库,以供所述第二数据库基于所述闩锁授权信息创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的所述第二数据页对应的日志序列号。
获取闩锁授权信息后,可以将闩锁授权信息发送至第二数据库,以授予第二数据库对应本地闩锁请求的闩锁权限。该闩锁授权信息可以供第二数据库生成控制日志,以减少创建数据页的操作。
本发明提供了一种数据页创建方法,该方法首先获取第二数据库的本地闩锁请求,所述本地闩锁请求用于向第一数据库请求第一数据页的闩锁权限;其次基于所述本地闩锁请求,确定对应的闩锁授权信息;最后将所述闩锁授权信息发送至所述第二数据库,以供所述第二数据库基于所述闩锁授权信息创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的所述第二数据页对应的日志序列号。利用该方法消除了从磁盘读取数据页或从远程节点读取数据页的操作,减少了数据页创建的代价,提升了数据库管理系统的整体执行效率。
在上述实施例的基础上,所述本地闩锁请求包括所述数据库节点的第一磁盘日志序列号集,所述第一磁盘日志序列号集包括所述数据库节点发送所述本地闩锁请求时写入磁盘中的第三数据页的日志序列号;所述闩锁授权信息包括:授权指示信息和全局磁盘日志序列号集,所述全局磁盘日志序列号集基于所述第一磁盘日志序列号集和所述其余磁盘日志序列号集更新确定,所述全局磁盘日志序列号集用于生成控制日志,所述全局磁盘日志序列号集包括目标数据库节点写入磁盘中的第四数据页的日志序列号,所述目标数据库节点为存在数据页修改的数据库节点。
在上述实施例的基础上,该方法还包括:根据所述第一磁盘日志序列号集更新所述全局磁盘日志序列号集。
获取本地闩锁请求后,可以基于本地闩锁请求所包括的第一磁盘日志序列号集更新全局磁盘日志序列号集,即将第一磁盘日志序列号集写入全局磁盘日志序列号集中。
实施例四
图4为本发明实施例四提供的一种数据页创建方法的流程示意图,本实施例在上述各实施例的基础上进行具体化。在本实施例中,将基于所述本地闩锁请求,确定对应的闩锁授权信息,具体包括:
基于所述本地闩锁请求判断是否存在冲突数据库,所述冲突数据库已获得所述第一数据页的闩锁权限;
基于判断结果,确定全局磁盘日志序列号集;
基于所述全局磁盘日志序列号集和授权指示信息,确定闩锁授权信息。
本实施例尚未详尽之处请参见上述实施例。
如图4所示,本发明实施例提供的一种数据页创建方法,包括:
S410、获取第二数据库的本地闩锁请求,所述本地闩锁请求用于向第一数据库请求第一数据页的闩锁权限。
S420、基于所述本地闩锁请求判断是否存在冲突数据库,所述冲突数据库已获得所述第一数据页的闩锁权限。
确定闩锁授权信息时,本步骤可以首先基于本地闩锁请求确定是否存在冲突数据库。冲突数据库可以认为是已经获取第一数据页的闩锁权限的数据库。
本步骤确定是否存在冲突数据库时,可以基于本地闩锁请求所包括的待封锁对象和闩封锁模式确定是否存在冲突数据库。冲突数据库可以认为已经获取所述待封锁对应的所述闩封锁模式。
S430、基于判断结果,确定全局磁盘日志序列号集。
判断结果可以认为是判断是否存在冲突数据库的结果。判断结果可以包括存在冲突数据库和不存在冲突数据库。本步骤可以基于判断结果确定全局磁盘日志序列号集,以获得闩锁授权信息。
在基于判断结果确定全局磁盘日志序列号集时,若判断结果为存在冲突数据库,可以基于闩锁权限回收后的信息,如第二响应信息确定全局磁盘日志序列号集;若判断结果为不存在冲突数据库,可以直接获取当前第一数据库存储的全局磁盘日志序列集。
S440、基于所述全局磁盘日志序列号集和授权指示信息,确定闩锁授权信息。
获取全局磁盘日志序列号集后,可以将全局日志序列号集和授权指示信息,封装至闩锁授权信息中。闩锁授权信息包括全局磁盘日志序列号集和授权指示信息。
S450、将所述闩锁授权信息发送至所述第二数据库,以供所述第二数据库基于所述闩锁授权信息创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的所述第二数据页对应的日志序列号。
以下对本实施例进行示例性的描述:
本发明在全局闩服务对象GBS_POOL增加FILE_LSN_ARR数组,即全局磁盘日志序列号集,以节点号作为数组下标,用来记录各节点的FILE_LSN值,全局闩服务从节点本地闩服务回收数据页权限时,获取对应节点的FILE_LSN值,并填充到FILE_LSN_ARR数组中。在本地闩服务对象LBS_POOL增加FILE_LSN_ARR数组,即本地磁盘日志序列号集,以节点号作为数组下标,用来记录各节点的FILE_LSN值,全局闩服务响应节点的本地闩服务请求(即本地闩请求)时,附带返回GBS_POOL上各节点的FILE_LSN值,即全局磁盘日志序列号集。
系统初始化时,使用各节点的FILE_LSN填充全局闩服务对象和本地闩服务对象的FILE_LSN_ARR数组。数据页创建操作通过本地闩服务获取闩封锁的同时,获取其他节点的FILE_LSN值,并生成APPLY LSN WAIT日志,即控制日志,记录其他节点的FILE_LSN值,APPLYLSN WAIT日志自身的LSN值取当前节点CUR_LSN和其他节点FILE_LSN+1的最大值。共享存储集群故障重启时,对各节点的REDO日志根据LSN值进行排序,并严格按照LSN从小到大排序重做REDO日志,将数据恢复到系统故障前状态。
本实施例中数据页创建方法可以包括如下步骤:
(1)收到数据页P1的X请求,先将节点的FILE_LSN值记录到GBS_POOL的FILE_LSN_ARR数组中,再检查是否存在节点封锁冲突,如果存在冲突,则执行步骤(2),否则执行步骤(4)。
(2)向冲突节点,即冲突数据库发起权限回收请求,并等待对应节点的本地闩服务响应,即第二响应信息。
(3)收到冲突节点本地闩服务响应后,将对应节点的FILE_LSN值,即第三磁盘日志序列号集记录到GBS_POOL的FILE_LSN_ARR数组。
(4)授予请求节点X闩锁请求,并附带GBS_POOL的FILE_LSN_ARR信息。
全局闩服务对象的FILE_LSN_ARR数组中各节点的FILE_LSN值不一定是最新的,根据本地闩服务/全局闩服务的实现机制,以及数据页REMOTE READ的实现机制,可以确保数据页创建时,获取到的各节点FILE_LSN值,一定不小于数据页的PAGE_LSN值。
场景1:
1.节点EP0释放数据页P1操作生成的REDO日志的LSN值是1000,并且LSN值1000会写入数据页P1。
2.节点EP1创建数据页P1,通过本地闩服务获取P1的X闩锁,本地闩服务会向全局闩服务请求X闩锁权限。
3.全局闩服务收到EP1的X请求,从EP0回收P1的闩锁权限时,EP0会确保数据页P1的PAGE_LSN对应的日志写入磁盘后,再响应全局闩服务,此时节点EP0的FILE_LSN一定不小于1000。
4.全局闩服务将EP0的FILE_LSN值通知EP1,EP1生成的APPLY LSN WAIT日志的LSN值一定不小于1001,大于数据页P1的PAGE_LSN(1000)。
场景2:
1.节点EP0释放数据页P1操作生成的REDO日志的LSN值是1000,并且LSN值1000会写入数据页P1。
2.节点EP0由于缓存淘汰等原因,数据页P1被写入磁盘前,必须确保LSN小于等于1000的REDO先写入磁盘,此时节点EP0的FILE_LSN一定不小于1000。并且,在全局闩服务中,节点EP0仍然拥有P1的X闩锁权限。
3.节点EP1创建数据页P1,通过本地闩服务获取P1的X闩锁权限,本地闩服务会向全局闩服务请求X闩锁权限。
4.全局闩服务收到EP1的X请求,仍然会从EP0回收P1的闩锁,EP0返回的FILE_LSN值一定不小于1000。
5.全局闩服务将EP0的FILE_LSN值通知EP1,EP1生成的APPLY LSN WAIT日志的LSN值一定不小于1001,大于数据页P1的PAGE_LSN(1000)。
场景3:
1.节点EP0释放数据页P1操作生成的REDO日志的LSN值是1000,并且LSN值1000会写入数据页P1。
2.节点EP0由于缓存淘汰等原因,数据页P1被写入磁盘前,必须确保LSN小于等于1000的REDO先写入磁盘,此时节点EP0的FILE_LSN一定不小于1000。并且,在全局闩服务中,节点EP0仍然拥有P1的X闩锁权限。
3.全局闩服务触发数据页控制结构淘汰机制,需要淘汰数据页P1对应的控制结构,由于节点EP0仍然拥有P1的X闩锁权限,全局闩服务会先从EP0回收P1的闩锁权限,EP0返回的FILE_LSN值一定不小于1000。
4.节点EP1创建数据页P1,通过本地闩服务获取P1的X闩锁权限时,本地闩服务会向全局闩服务请求X闩锁权限。
5.全局闩服务收到EP1的X请求,向EP1授予P1的闩锁权限时,FILE_LSN_ARR数组中,EP0的FILE_LSN值一定不小于1000。
6.全局闩服务将EP0的FILE_LSN值通知EP1,EP1生成的APPLY LSN WAIT日志的LSN值一定不小于1001,大于数据页P1的PAGE_LSN(1000)。
本发明实施例提供了一种数据页创建方法,该方法具体化了确定闩锁授权信息的操作。利用该方法通过判断是否存在冲突数据库,有效的确定了全局磁盘日志序列号集,从而确定闩锁授权信息,以供第二数据库生成控制日志,减少了创建数据页的代价,提升了创建数据页的效率。
在上述实施例的基础上,所述基于判断结果,确定全局磁盘日志序列号集,包括:
若判断结果为存在冲突数据库,则向所述冲突数据库发送第二权限回收请求;
接收所述第二权限回收请求对应的第二响应信息,所述第二响应信息包括所述冲突数据库的第三磁盘日志序列号集,所述第三磁盘日志序列号集为所述冲突数据库写入磁盘中的第六数据页的日志序列号;
基于所述第三磁盘日志序列号集更新所述全局磁盘日志序列号集。
第二权限回收请求可以理解为第一数据库发送至冲突数据库的进行闩锁权限回收的请求。第二权限回收请求所包括的内容不作限定,示例性的,第二权限回收请求可以包括回收对象,如第一数据页。第一数据库向冲突数据库发送第二权限回收请求以回收相应的闩锁权限。
第二响应信息可以认为是冲突数据库在第二权限回收请求对应的闩锁权限被释放后反馈的响应信息。第六数据页可以认为是冲突数据库写入磁盘最大的数据页日志序列号对应的数据页。第三磁盘日志序列号集可以作为其他磁盘日志序列号集更新全局磁盘日志序列号集,从而基于更新后的全局磁盘日志序列号集生成控制日志。
在上述实施例的基础上,所述基于判断结果,确定全局磁盘日志序列号集,包括:
若判断结果为不存在冲突数据库,则获取全局磁盘日志序列号集。
如果判断结果不存在冲突数据库,可以直接获取第一数据库本地存储的全局磁盘日志序列号集,以生成控制日志。
实施例五
图5为本发明实施例五提供的一种数据页创建装置的结构示意图,该装置可适用于创建数据页的情况。具体的,适用于减少创建数据页创建代价的情况。其中该装置可以由软件和/或硬件实现,并一般集成在终端设备上。
如图5所示,该装置包括:
第一接收模块51,用于接收数据库节点的节点闩锁请求,所述节点闩锁请求为创建第一数据页的请求;
发送模块52,用于若本地不存在所述第一数据页的闩锁权限,则向第一数据库发送本地闩锁请求,所述本地闩锁请求用于向所述第一数据库请求所述第一数据页的闩锁权限;
第二接收模块53,用于接收所述第一数据库发送的对应所述本地闩锁请求的闩锁授权信息;
创建模块54,用于基于所述闩锁授权信息,创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的第二数据页的日志序列号。
在本实施例中,该装置首先通过第一接收模块51接收数据库节点的节点闩锁请求,所述节点闩锁请求为创建第一数据页的请求;其次通过发送模块52若本地不存在所述第一数据页的闩锁权限,则向第一数据库发送本地闩锁请求,所述本地闩锁请求用于向所述第一数据库请求所述第一数据页的闩锁权限;然后通过第二接收模块53接收所述第一数据库发送的对应所述本地闩锁请求的闩锁授权信息;最后通过创建模块54基于所述闩锁授权信息,创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的第二数据页的日志序列号。本实施例提供了一种数据页创建装置,利用该装置消除了从磁盘读取数据页或从远程节点读取数据页的操作,减少了数据页创建的代价,提升了数据库管理系统的整体执行效率。
进一步地,所述本地闩锁请求包括所述数据库节点的第一磁盘日志序列号集,所述第一磁盘日志序列号集包括所述数据库节点发送所述本地闩锁请求时写入磁盘中的第三数据页的日志序列号;所述闩锁授权信息包括:授权指示信息和全局磁盘日志序列号集,所述全局磁盘日志序列号集基于所述第一磁盘日志序列号集和所述其余磁盘日志序列号集更新确定,所述全局磁盘日志序列号集用于生成控制日志,所述全局磁盘日志序列号集包括目标数据库节点写入磁盘中的第四数据页的日志序列号,所述目标数据库节点为存在数据页修改的数据库节点。
进一步地,创建模块54具体用于:
基于所述全局磁盘日志序列号集中其余磁盘日志序列号集更新本地磁盘日志序列号集;
基于所述其余磁盘日志序列号集,生成控制日志;
基于所述授权指示信息执行闩封锁,并创建第一数据页,生成对应的重做日志。
进一步地,该装置,还包括:响应模块,用于:
获取第一数据库发送的第一权限回收请求;
在对应所述第一权限回收请求的闩锁权限被释放时,向所述第一数据库发送第一响应信息,所述第一响应信息包括所述数据库节点的第二磁盘日志序列号集,所述第二磁盘日志序列号集包括所述数据库节点发送第一响应信息时写入磁盘中的第五数据页的日志序列号。
实施例六
图6为本发明实施例六提供的一种数据页创建装置的结构示意图,该装置可适用于创建数据页的情况。具体的,适用于减少创建页创建代价的情况。其中该装置可以由软件和/或硬件实现,并一般集成在终端设备上。
如图6所示,该装置包括:
获取模块61,用于获取第二数据库的本地闩锁请求,所述本地闩锁请求用于向第一数据库请求第一数据页的闩锁权限;
确定模块62,用于基于所述本地闩锁请求,确定对应的闩锁授权信息;
发送模块63,用于将所述闩锁授权信息发送至所述第二数据库,以供所述第二数据库基于所述闩锁授权信息创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的所述第二数据页对应的日志序列号。
在本实施例中,该装置首先通过获取模块61获取第二数据库的节点闩锁请求,所述节点闩锁请求为创建第一数据页的请求;然后通过确定模块62基于所述节点闩锁请求,确定对应的闩锁授权信息;最后通过发送模块63将所述闩锁授权信息发送至所述第二数据库,以供所述第二数据库基于所述闩锁授权信息创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的所述第二数据页对应的日志序列号。
本实施例提供了一种数据页创建装置,利用该装置消除了从磁盘读取数据页或从远程节点读取数据页的操作,减少了数据页创建的代价,提升了数据库管理系统的整体执行效率。
进一步地,所述本地闩锁请求包括所述数据库节点的第一磁盘日志序列号集,所述第一磁盘日志序列号集包括所述数据库节点发送所述本地闩锁请求时写入磁盘中的第三数据页的日志序列号;所述闩锁授权信息包括:授权指示信息和全局磁盘日志序列号集,所述全局磁盘日志序列号集基于所述第一磁盘日志序列号集和所述其余磁盘日志序列号集更新确定,所述全局磁盘日志序列号集用于生成控制日志,所述全局磁盘日志序列号集包括目标数据库节点写入磁盘中的第四数据页的日志序列号,所述目标数据库节点为存在数据页修改的数据库节点。
进一步地,该装置,还包括:更新模块,用于:
根据所述第一磁盘日志序列号集更新所述全局磁盘日志序列号集。
进一步地,确定模块62具体用于:
基于所述本地闩锁请求判断是否存在冲突数据库,所述冲突数据库已获得所述第一数据页的闩锁权限;
基于判断结果,确定全局磁盘日志序列号集;
基于所述全局磁盘日志序列号集和授权指示信息,确定闩锁授权信息。
进一步地,确定模块62基于判断结果,确定全局磁盘日志序列号集,包括:
若判断结果为存在冲突数据库,则向所述冲突数据库发送第二权限回收请求;
接收所述第二权限回收请求对应的第二响应信息,所述第二响应信息包括所述冲突数据库的第三磁盘日志序列号集,所述第三磁盘日志序列号集为所述冲突数据库写入磁盘中的第六数据页的日志序列号;
基于所述第三磁盘日志序列号集更新所述全局磁盘日志序列号集。
进一步地,确定模块62基于判断结果,确定全局磁盘日志序列号集,包括:
若判断结果为不存在冲突数据库,则获取全局磁盘日志序列号集。
实施例七
图7为本发明实施例七提供的终端设备的结构示意图,如图7所示,本发明实施例七提供了一种终端设备包括:一个或多个处理器41和存储装置42;该终端设备中的处理器41可以是一个或多个,图7中以一个处理器41为例;存储装置42用于存储一个或多个程序;所述一个或多个程序被所述一个或多个处理器41执行,使得所述一个或多个处理器41实现如本发明实施例一或二所述的数据页创建方法。
所述终端设备还可以包括:输入装置43、输出装置44和通信装置45,通信装置45,用于实现终端设备的外部通信。通信装置45连接一个或多个处理器41。
终端设备中的处理器41、存储装置42、输入装置43、输出装置44和通信装置45可以通过总线或其他方式连接,图7中以通过总线连接为例。
该终端设备中的存储装置42作为一种计算机可读存储介质,可用于存储一个或多个程序,所述程序可以是软件程序、计算机可执行程序以及模块,如本发明实施例一或二所提供的数据页创建方法对应的程序指令/模块(例如,附图5所示的数据页创建装置中的模块,包括:第一接收模块51、发送模块52、第二接收模块53和创建模块54)。处理器41通过运行存储在存储装置42中的软件程序、指令以及模块,从而执行终端设备的各种功能应用以及数据处理,即实现上述方法实施例中数据页创建方法。
存储装置42可包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序;存储数据区可存储根据终端设备的使用所创建的数据等。此外,存储装置42可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他非易失性固态存储器件。在一些实例中,存储装置42可进一步包括相对于处理器41远程设置的存储器,这些远程存储器可以通过网络连接至设备。上述网络的实例包括但不限于互联网、企业内部网、局域网、移动通信网及其组合。
输入装置43可用于接收输入的数字或字符信息,以及产生与终端设备的用户设置以及功能控制有关的键信号输入。输出装置44可包括显示屏等显示设备。
并且,当上述终端设备所包括一个或者多个程序被所述一个或者多个处理器41执行时,程序进行如下操作:
接收数据库节点的节点闩锁请求,所述节点闩锁请求为创建第一数据页的请求;
若本地不存在所述第一数据页的闩锁权限,则向第一数据库发送本地闩锁请求,所述本地闩锁请求用于向所述第一数据库请求所述第一数据页的闩锁权限;
接收所述第一数据库发送的对应所述本地闩锁请求的闩锁授权信息;
基于所述闩锁授权信息,创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的第二数据页的日志序列号。
实施例八
图8为本发明实施例八提供的终端设备的结构示意图,如图8所示,本发明实施例八提供了一种终端设备包括:一个或多个处理器51和存储装置52;该终端设备中的处理器51可以是一个或多个,图8中以一个处理器51为例;存储装置52用于存储一个或多个程序;所述一个或多个程序被所述一个或多个处理器51执行,使得所述一个或多个处理器51实现如本发明实施例三或四所述的数据页创建方法。
所述终端设备还可以包括:输入装置53、输出装置54和通信装置55,通信装置55,用于实现终端设备的外部通信。通信装置55连接一个或多个处理器51。
终端设备中的处理器51、存储装置52、输入装置53、输出装置54和通信装置55可以通过总线或其他方式连接,图8中以通过总线连接为例。
该终端设备中的存储装置52作为一种计算机可读存储介质,可用于存储一个或多个程序,所述程序可以是软件程序、计算机可执行程序以及模块,如本发明实施例三或四所提供的数据页创建方法对应的程序指令/模块(例如,附图6所示的数据页创建装置中的模块,包括:获取模块61、确定模块62和发送模块63)。处理器51通过运行存储在存储装置52中的软件程序、指令以及模块,从而执行终端设备的各种功能应用以及数据处理,即实现上述方法实施例三或四中数据页创建方法。
存储装置52可包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序;存储数据区可存储根据终端设备的使用所创建的数据等。此外,存储装置52可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他非易失性固态存储器件。在一些实例中,存储装置52可进一步包括相对于处理器51远程设置的存储器,这些远程存储器可以通过网络连接至设备。上述网络的实例包括但不限于互联网、企业内部网、局域网、移动通信网及其组合。
输入装置53可用于接收输入的数字或字符信息,以及产生与终端设备的用户设置以及功能控制有关的键信号输入。输出装置54可包括显示屏等显示设备。
并且,当上述终端设备所包括一个或者多个程序被所述一个或者多个处理器51执行时,程序进行如下操作:
获取第二数据库的本地闩锁请求,所述本地闩锁请求用于向第一数据库请求第一数据页的闩锁权限;
基于所述本地闩锁请求,确定对应的闩锁授权信息;
将所述闩锁授权信息发送至所述第二数据库,以供所述第二数据库基于所述闩锁授权信息创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的所述第二数据页对应的日志序列号。
实施例九
本发明实施例九提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时用于执行本发明提供的数据页创建方法,该方法包括:
接收数据库节点的节点闩锁请求,所述节点闩锁请求为创建第一数据页的请求;
若本地不存在所述第一数据页的闩锁权限,则向第一数据库发送本地闩锁请求,所述本地闩锁请求用于向所述第一数据库请求所述第一数据页的闩锁权限;
接收所述第一数据库发送的对应所述本地闩锁请求的闩锁授权信息;
基于所述闩锁授权信息,创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的第二数据页的日志序列号。
或,该方法包括:
获取第二数据库的本地闩锁请求,所述本地闩锁请求用于向第一数据库请求第一数据页的闩锁权限;
基于所述本地闩锁请求,确定对应的闩锁授权信息;
将所述闩锁授权信息发送至所述第二数据库,以供所述第二数据库基于所述闩锁授权信息创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的所述第二数据页对应的日志序列号。
可选的,该程序被处理器执行时还可以用于执行本发明任意实施例所提供的数据页创建方法。
本发明实施例的计算机存储介质,可以采用一个或多个计算机可读的介质的任意组合。计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机存取存储器(Random AccessMemory,RAM)、只读存储器(Read Only Memory,ROM)、可擦式可编程只读存储器(ErasableProgrammable Read Only Memory,EPROM)、闪存、光纤、便携式CD-ROM、光存储器件、磁存储器件、或者上述的任意合适的组合。计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。
计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于:电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。
计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、无线电频率(Radio Frequency,RF)等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言或其组合来编写用于执行本发明操作的计算机程序代码,所述程序设计语言包括面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)——连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
注意,上述仅为本发明的较佳实施例及所运用技术原理。本领域技术人员会理解,本发明不限于这里所述的特定实施例,对本领域技术人员来说能够进行各种明显的变化、重新调整和替代而不会脱离本发明的保护范围。因此,虽然通过以上实施例对本发明进行了较为详细的说明,但是本发明不仅仅限于以上实施例,在不脱离本发明构思的情况下,还可以包括更多其他等效实施例,而本发明的范围由所附的权利要求范围决定。
Claims (15)
1.一种数据页创建方法,其特征在于,包括:
接收数据库节点的节点闩锁请求,所述节点闩锁请求为创建第一数据页的请求;
若本地不存在所述第一数据页的闩锁权限,则向第一数据库发送本地闩锁请求,所述本地闩锁请求用于向所述第一数据库请求所述第一数据页的闩锁权限;
接收所述第一数据库发送的对应所述本地闩锁请求的闩锁授权信息;
基于所述闩锁授权信息,创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的第二数据页的日志序列号。
2.根据权利要求1所述的方法,其特征在于,所述本地闩锁请求包括所述数据库节点的第一磁盘日志序列号集,所述第一磁盘日志序列号集包括所述数据库节点发送所述本地闩锁请求时写入磁盘中的第三数据页的日志序列号;所述闩锁授权信息包括:授权指示信息和全局磁盘日志序列号集,所述全局磁盘日志序列号集基于所述第一磁盘日志序列号集和所述其余磁盘日志序列号集更新确定,所述全局磁盘日志序列号集用于生成控制日志,所述全局磁盘日志序列号集包括目标数据库节点写入磁盘中的第四数据页的日志序列号,所述目标数据库节点为存在数据页修改的数据库节点。
3.根据权利要求2所述的方法,其特征在于,所述基于所述闩锁授权信息,创建第一数据页并生成控制日志,包括:
基于所述全局磁盘日志序列号集中其余磁盘日志序列号集更新本地磁盘日志序列号集;
基于所述其余磁盘日志序列号集,生成控制日志;
基于所述授权指示信息执行闩封锁,并创建第一数据页,生成对应的重做日志。
4.根据权利要求1所述的方法,其特征在于,还包括:
获取第一数据库发送的第一权限回收请求;
在对应所述第一权限回收请求的闩锁权限被释放时,向所述第一数据库发送第一响应信息,所述第一响应信息包括所述数据库点的第二磁盘日志序列号集,所述第二磁盘日志序列号集包括所述数据库节点发送第一响应信息时写入磁盘中的第五数据页的日志序列号。
5.一种数据页创建方法,其特征在于,包括:
获取第二数据库的本地闩锁请求,所述本地闩锁请求用于向第一数据库请求第一数据页的闩锁权限;
基于所述本地闩锁请求,确定对应的闩锁授权信息;
将所述闩锁授权信息发送至所述第二数据库,以供所述第二数据库基于所述闩锁授权信息创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的所述第二数据页对应的日志序列号。
6.根据权利要求5所述的方法,其特征在于,所述本地闩锁请求包括所述数据库节点的第一磁盘日志序列号集,所述第一磁盘日志序列号集包括所述数据库节点发送所述本地闩锁请求时写入磁盘中的第三数据页的日志序列号;所述闩锁授权信息包括:授权指示信息和全局磁盘日志序列号集,所述全局磁盘日志序列号集基于所述第一磁盘日志序列号集和所述其余磁盘日志序列号集更新确定,所述全局磁盘日志序列号集用于生成控制日志,所述全局磁盘日志序列号集包括目标数据库节点写入磁盘中的第四数据页的日志序列号,所述目标数据库节点为存在数据页修改的数据库节点。
7.根据权利要求6所述的方法,其特征在于,还包括:
根据所述第一磁盘日志序列号集更新所述全局磁盘日志序列号集。
8.根据权利要求5所述的方法,其特征在于,所述基于所述本地闩锁请求,确定对应的闩锁授权信息,包括:
基于所述本地闩锁请求判断是否存在冲突数据库,所述冲突数据库已获得所述第一数据页的闩锁权限;
基于判断结果,确定全局磁盘日志序列号集;
基于所述全局磁盘日志序列号集和授权指示信息,确定闩锁授权信息。
9.根据权利要求8所述的方法,其特征在于,所述基于判断结果,确定全局磁盘日志序列号集,包括:
若判断结果为存在冲突数据库,则向所述冲突数据库发送第二权限回收请求;
接收所述第二权限回收请求对应的第二响应信息,所述第二响应信息包括所述冲突数据库的第三磁盘日志序列号集,所述第三磁盘日志序列号集为所述冲突数据库写入磁盘中的第六数据页的日志序列号;
基于所述第三磁盘日志序列号集更新所述全局磁盘日志序列号集。
10.根据权利要求8所述的方法,其特征在于,所述基于判断结果,确定全局磁盘日志序列号集,包括:
若判断结果为不存在冲突数据库,则获取全局磁盘日志序列号集。
11.一种数据页创建装置,其特征在于,包括:
第一接收模块,用于接收数据库节点的节点闩锁请求,所述节点闩锁请求为创建第一数据页的请求;
发送模块,用于若本地不存在所述第一数据页的闩锁权限,则向第一数据库发送本地闩锁请求,所述本地闩锁请求用于向所述第一数据库请求所述第一数据页的闩锁权限;
第二接收模块,用于接收所述第一数据库发送的对应所述本地闩锁请求的闩锁授权信息;
创建模块,用于基于所述闩锁授权信息,创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的第二数据页的日志序列号。
12.一种数据页创建装置,其特征在于,包括:
获取模块,用于获取第二数据库的本地闩锁请求,所述本地闩锁请求用于向第一数据库请求第一数据页的闩锁权限;
确定模块,用于基于所述本地闩锁请求,确定对应的闩锁授权信息;
发送模块,用于将所述闩锁授权信息发送至所述第二数据库,以供所述第二数据库基于所述闩锁授权信息创建第一数据页并生成控制日志,所述控制日志用于指示其余磁盘日志序列号集,所述其余磁盘日志序列号集包括除所述数据库节点外的其余节点写入磁盘中的所述第二数据页对应的日志序列号。
13.一种终端设备,其特征在于,包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序;
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1-4中任一所述的方法。
14.一种终端设备,其特征在于,包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序;
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求5-10中任一所述的方法。
15.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1-10中任一所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010238596.4A CN111444147B (zh) | 2020-03-30 | 2020-03-30 | 一种数据页创建方法、装置、终端设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010238596.4A CN111444147B (zh) | 2020-03-30 | 2020-03-30 | 一种数据页创建方法、装置、终端设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN111444147A true CN111444147A (zh) | 2020-07-24 |
CN111444147B CN111444147B (zh) | 2023-05-12 |
Family
ID=71651181
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010238596.4A Active CN111444147B (zh) | 2020-03-30 | 2020-03-30 | 一种数据页创建方法、装置、终端设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN111444147B (zh) |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112084261A (zh) * | 2020-09-03 | 2020-12-15 | 上海达梦数据库有限公司 | 一种数据同步方法、系统、节点及存储介质 |
CN112395141A (zh) * | 2020-11-25 | 2021-02-23 | 上海达梦数据库有限公司 | 一种数据页管理方法、装置、电子设备及存储介质 |
CN112596953A (zh) * | 2020-12-25 | 2021-04-02 | 上海达梦数据库有限公司 | 数据库日志重演方法、装置、设备及存储介质 |
CN113377502A (zh) * | 2021-06-10 | 2021-09-10 | 上海达梦数据库有限公司 | 事务处理方法、装置、服务器、数据库管理系统及介质 |
CN113420012A (zh) * | 2021-07-14 | 2021-09-21 | 上海达梦数据库有限公司 | 数据库节点管理方法、装置、数据库节点及存储介质 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20140279929A1 (en) * | 2013-03-15 | 2014-09-18 | Amazon Technologies, Inc. | Database system with database engine and separate distributed storage service |
CN108073656A (zh) * | 2016-11-17 | 2018-05-25 | 杭州华为数字技术有限公司 | 一种数据同步方法及相关设备 |
CN108416040A (zh) * | 2018-03-14 | 2018-08-17 | 上海达梦数据库有限公司 | 一种数据库修复方法、装置、终端设备及存储介质 |
CN109063132A (zh) * | 2018-08-02 | 2018-12-21 | 上海达梦数据库有限公司 | 闩锁请求方法、闩锁授权方法、装置及终端设备 |
CN109408519A (zh) * | 2018-11-08 | 2019-03-01 | 上海达梦数据库有限公司 | 一种数据页的访问方法、装置、服务器及存储介质 |
-
2020
- 2020-03-30 CN CN202010238596.4A patent/CN111444147B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20140279929A1 (en) * | 2013-03-15 | 2014-09-18 | Amazon Technologies, Inc. | Database system with database engine and separate distributed storage service |
CN108073656A (zh) * | 2016-11-17 | 2018-05-25 | 杭州华为数字技术有限公司 | 一种数据同步方法及相关设备 |
CN108416040A (zh) * | 2018-03-14 | 2018-08-17 | 上海达梦数据库有限公司 | 一种数据库修复方法、装置、终端设备及存储介质 |
CN109063132A (zh) * | 2018-08-02 | 2018-12-21 | 上海达梦数据库有限公司 | 闩锁请求方法、闩锁授权方法、装置及终端设备 |
CN109408519A (zh) * | 2018-11-08 | 2019-03-01 | 上海达梦数据库有限公司 | 一种数据页的访问方法、装置、服务器及存储介质 |
Non-Patent Citations (1)
Title |
---|
陈游?;朱博弘;韩银俊;屠要峰;舒继武;: "一种持久性内存文件系统数据页的混合管理机制" * |
Cited By (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112084261A (zh) * | 2020-09-03 | 2020-12-15 | 上海达梦数据库有限公司 | 一种数据同步方法、系统、节点及存储介质 |
CN112084261B (zh) * | 2020-09-03 | 2024-05-10 | 上海达梦数据库有限公司 | 一种数据同步方法、系统、节点及存储介质 |
CN112395141A (zh) * | 2020-11-25 | 2021-02-23 | 上海达梦数据库有限公司 | 一种数据页管理方法、装置、电子设备及存储介质 |
CN112395141B (zh) * | 2020-11-25 | 2023-07-21 | 上海达梦数据库有限公司 | 一种数据页管理方法、装置、电子设备及存储介质 |
CN112596953A (zh) * | 2020-12-25 | 2021-04-02 | 上海达梦数据库有限公司 | 数据库日志重演方法、装置、设备及存储介质 |
CN112596953B (zh) * | 2020-12-25 | 2023-08-29 | 上海达梦数据库有限公司 | 数据库日志重演方法、装置、设备及存储介质 |
CN113377502A (zh) * | 2021-06-10 | 2021-09-10 | 上海达梦数据库有限公司 | 事务处理方法、装置、服务器、数据库管理系统及介质 |
CN113420012A (zh) * | 2021-07-14 | 2021-09-21 | 上海达梦数据库有限公司 | 数据库节点管理方法、装置、数据库节点及存储介质 |
CN113420012B (zh) * | 2021-07-14 | 2024-04-09 | 上海达梦数据库有限公司 | 数据库节点管理方法、装置、数据库节点及存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN111444147B (zh) | 2023-05-12 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN111444147B (zh) | 一种数据页创建方法、装置、终端设备及存储介质 | |
CN108363806B (zh) | 数据库的多版本并发控制方法、装置、服务器及存储介质 | |
US8868850B2 (en) | Recovering data segment contents in a distributed shared memory | |
CN109491928B (zh) | 缓存控制方法、装置、终端及存储介质 | |
US6412034B1 (en) | Transaction-based locking approach | |
US20070143299A1 (en) | Commitment of transactions in a distributed system | |
US9460144B2 (en) | Lock acceleration | |
CN108572876B (zh) | 一种读写锁的实现方法及装置 | |
US6970872B1 (en) | Techniques for reducing latency in a multi-node system when obtaining a resource that does not reside in cache | |
US7818749B2 (en) | Data processing method, data processing apparatus, and data processing program | |
CN112099962B (zh) | 分布式锁实现方法、装置和电子设备 | |
CN109063132B (zh) | 闩锁请求方法、闩锁授权方法、装置及终端设备 | |
CN113342507B (zh) | 一种分布式锁服务实现方法、装置及计算机设备 | |
US7840671B2 (en) | Managing the size and accessibility of a name service | |
CN109542922B (zh) | 针对实时服务数据的处理方法及相关系统 | |
CN107967265B (zh) | 文件的访问方法、数据服务器和文件访问系统 | |
CN112395141B (zh) | 一种数据页管理方法、装置、电子设备及存储介质 | |
CN103714059A (zh) | 一种更新数据的方法及装置 | |
CN114036195A (zh) | 一种数据请求处理方法、装置、服务器和存储介质 | |
CN115220907A (zh) | 资源调度方法、装置、电子设备及存储介质 | |
CN111405015A (zh) | 一种数据处理方法、装置、设备及存储介质 | |
CN113553488A (zh) | 搜索引擎中索引数据的更新方法、装置、电子设备及介质 | |
US8838910B2 (en) | Multi-part aggregated variable in structured external storage | |
CN113051081B (zh) | 基于内存池的事件状态管理方法、系统及存储介质 | |
KR102460910B1 (ko) | 데이터 중복 방지를 위한 데이터 저장 방법 및 이를 적용한 데이터 플랫폼 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |