CN116821247A - 一种数据同步方法、装置、设备及存储介质 - Google Patents

一种数据同步方法、装置、设备及存储介质 Download PDF

Info

Publication number
CN116821247A
CN116821247A CN202310861300.8A CN202310861300A CN116821247A CN 116821247 A CN116821247 A CN 116821247A CN 202310861300 A CN202310861300 A CN 202310861300A CN 116821247 A CN116821247 A CN 116821247A
Authority
CN
China
Prior art keywords
target
subscription
archive
library
log file
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.)
Pending
Application number
CN202310861300.8A
Other languages
English (en)
Inventor
郭振岗
陆宏达
韩朱忠
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Shanghai Dameng Database Co Ltd
Original Assignee
Shanghai Dameng Database Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Shanghai Dameng Database Co Ltd filed Critical Shanghai Dameng Database Co Ltd
Priority to CN202310861300.8A priority Critical patent/CN116821247A/zh
Publication of CN116821247A publication Critical patent/CN116821247A/zh
Pending legal-status Critical Current

Links

Landscapes

  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本发明公开了一种数据同步方法、装置、设备及存储介质。该方法包括:当所述归档配置文件中的目标定时器触发时,根据归档配置文件中的主库连接信息建立与订阅主库之间的连接;获取目标LSN值,并根据所述目标LSN值生成同步请求指令,并将所述同步请求指令发送至订阅主库;接收订阅主库发送的所述目标LSN值对应的目标归档日志文件;根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步,通过本发明的技术方案,能够解决由于主库产生的归档日志较多,造成备库的日志重演速度赶不上主库的日志产生速度,进而导致主备系统出现异常的问题,提升了订阅备库的独立性和订阅主库配置的灵活性,并且订阅主库能够连续对外提供服务。

Description

一种数据同步方法、装置、设备及存储介质
技术领域
本发明实施例涉及计算机技术领域,尤其涉及一种数据同步方法、装置、设备及存储介质。
背景技术
为了保证数据的安全性,防止意外情况的发生,通常需要将数据库系统配置成主备系统,用户对数据库的日常操作在主库上进行,主库修改数据后,会将修改内容记录到归档日志文件中,然后将归档日志文件发送至备库,备库根据归档日志同步修改数据(该过程称为日志重演),从而保证主库和备库上数据的一致性。上述过程称为主备库之间的数据同步。
异步主备系统是目前比较常用的一种非实时主备系统。在异步主备系统中,主库上需要配置定时器、归档配置文件、通讯模块配置文件;备库上也需配置归档配置文件、通讯模块配置文件。异步主备中,主库维护、发起归档日志同步:主库定时发送归档日志到备库上,备库收到后立即进行日志重演。通讯模块用于建立主库和备库之间的连接并进行消息通讯。
对于异步主备系统,如果主库产生的归档日志较多,可能造成备库的日志重演速度赶不上主库的日志产生速度,进而导致主备系统出现异常。另外主库需要不间断对外提供服务,但是配置主备系统需要在主库上配置归档日志以及通讯模块等信息,使得主库无法连续对外提供服务。
发明内容
本发明实施例提供一种数据同步方法、装置、设备及存储介质,本发明实施例中的归档配置文件均在订阅备库上进行配置,并且订阅主库和订阅备库之间不依赖通讯模块进行通讯,进而解决了由于主库产生的归档日志较多,造成备库的日志重演速度赶不上主库的日志产生速度,进而导致主备系统出现异常的问题,能够提升订阅备库的独立性和订阅主库配置的灵活性,并且订阅主库能够连续对外提供服务。
根据本发明的一方面,提供了一种数据同步方法,由订阅备库执行,所述方法包括:
当所述归档配置文件中的目标定时器触发时,根据归档配置文件中的主库连接信息建立与订阅主库之间的连接;
获取目标LSN值,并根据所述目标LSN值生成同步请求指令,并将所述同步请求指令发送至订阅主库;
接收订阅主库发送的所述目标LSN值对应的目标归档日志文件;
根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步。
根据本发明的另一方面,提供了一种数据同步方法,由订阅主库执行,所述方法包括:
接收订阅备库发送的同步请求指令,其中,所述同步请求指令携带目标LSN值;
获取所述目标LSN值对应的目标归档日志文件;
将所述目标LSN值对应的目标归档日志文件发送至所述订阅备库,以使所述订阅备库根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步。
根据本发明的另一方面,提供了一种数据同步装置,该数据同步装置包括:
连接建立模块,用于当归档配置文件中的目标定时器触发时,根据归档配置文件中的主库连接信息建立与订阅主库之间的连接;
同步请求指令发送模块,用于获取目标LSN值,并根据所述目标LSN值生成同步请求指令,并将所述同步请求指令发送至订阅主库;
归档日志文件接收模块,用于接收订阅主库发送的所述目标LSN值对应的目标归档日志文件;
数据同步模块,用于根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步。
根据本发明的另一方面,提供了一种数据同步装置,该数据同步装置包括:
同步请求指令接收模块,用于接收订阅备库发送的同步请求指令,其中,所述同步请求指令携带目标LSN值;
目标归档日志文件获取模块,用于获取所述目标LSN值对应的目标归档日志文件;
目标归档日志文件发送模块,用于将所述目标LSN值对应的目标归档日志文件发送至所述订阅备库,以使所述订阅备库根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步。
根据本发明的另一方面,提供了一种电子设备,所述电子设备包括:
至少一个处理器;以及
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的计算机程序,所述计算机程序被所述至少一个处理器执行,以使所述至少一个处理器能够执行本发明任一实施例所述的数据同步方法。
根据本发明的另一方面,提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机指令,所述计算机指令用于使处理器执行时实现本发明任一实施例所述的数据同步方法。
本发明实施例通过当所述归档配置文件中的目标定时器触发时,根据归档配置文件中的主库连接信息建立与订阅主库之间的连接;获取目标LSN值,并根据所述目标LSN值生成同步请求指令,并将所述同步请求指令发送至订阅主库;接收订阅主库发送的所述目标LSN值对应的目标归档日志文件;根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步,能够解决由于主库产生的归档日志较多,造成备库的日志重演速度赶不上主库的日志产生速度,进而导致主备系统出现异常的问题,提升了订阅备库的独立性和订阅主库配置的灵活性,并且订阅主库能够连续对外提供服务。
应当理解,本部分所描述的内容并非旨在标识本发明的实施例的关键或重要特征,也不用于限制本发明的范围。本发明的其它特征将通过以下的说明书而变得容易理解。
附图说明
为了更清楚地说明本发明实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本发明的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。
图1是本发明实施例中的一种数据同步方法的流程图;
图2是本发明实施例中的另一种数据同步方法的流程图;
图3是本发明实施例中的一种数据同步装置的结构示意图;
图4是本发明实施例中的另一种数据同步装置的结构示意图;
图5是本发明实施例中的一种电子设备的结构示意图。
具体实施方式
为了使本技术领域的人员更好地理解本发明方案,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分的实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都应当属于本发明保护的范围。
需要说明的是,本发明的说明书和权利要求书及上述附图中的术语“第一”、“第二”等是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的本发明的实施例能够以除了在这里图示或描述的那些以外的顺序实施。此外,术语“包括”和“具有”以及他们的任何变形,意图在于覆盖不排他的包含,例如,包含了一系列步骤或单元的过程、方法、系统、产品或设备不必限于清楚地列出的那些步骤或单元,而是可包括没有清楚地列出的或对于这些过程、方法、产品或设备固有的其它步骤或单元。
可以理解的是,在使用本公开各实施例公开的技术方案之前,均应当依据相关法律法规通过恰当的方式对本公开所涉及个人信息的类型、使用范围、使用场景等告知用户并获得用户的授权。
实施例一
图1为本发明实施例提供的一种数据同步方法的流程图,本实施例可适用于数据同步的情况,该方法可以由本发明实施例中的配置在订阅备库中的数据同步装置来执行,该装置可采用软件和/或硬件的方式实现,如图1所示,该方法具体包括如下步骤:
S110,当所述归档配置文件中的目标定时器触发时,根据归档配置文件中的主库连接信息建立与订阅主库之间的连接。
需要说明的是,订阅主备系统只需要在订阅备库上进行相关配置即可。用户需要在订阅备库上配置归档配置文件。其中,归档配置文件中可以设置以下信息:定时器名称(和定时器配置文件中的名称相对应)、订阅模式、归档目录(即归档日志文件的存放路径)以及主库连接信息等。归档配置文件还可以设置:归档类型(例如在本发明实施例中,将归档类型指定为订阅归档)。归档配置文件中还可配置其他很多扩展属性,在此不再赘述。用户还可以在订阅备库上配置定时器配置文件,其中,定时器配置文件中可以设置以下信息:定时器名称、定时器开始时间、定时器结束时间、每次触发的间隔时间等。
其中,主库连接信息可以包括:订阅主库的IP地址、端口号、用户名以及密码。主库连接信息也可设置为服务名或wallet文件地址等,订阅备库通过主库连接信息可以直接连接订阅主库,无需依赖通讯模块建立订阅主库和订阅备库之间的连接。
具体的,当所述归档配置文件中的目标定时器触发时,根据归档配置文件中的主库连接信息建立与订阅主库之间的连接的方式可以为:查询定时器配置文件得到归档配置文件中的目标定时器对应的触发条件,当目标定时器满足触发条件被触发时,根据归档配置文件中的主库连接信息建立与订阅主库之间的连接。当所述归档配置文件中的目标定时器触发时,根据归档配置文件中的主库连接信息建立与订阅主库之间的连接的方式还可以为:获取归档配置文件中的目标定时器名称;根据归档配置文件中的目标定时器名称查询定时器配置文件,得到归档配置文件中的目标定时器名称对应的定时器开始时间、定时器结束时间以及每次触发的间隔时间;当根据定时器开始时间、定时器结束时间以及每次触发的间隔时间确定目标定时器触发时,根据归档配置文件中的主库连接信息建立与订阅主库之间的连接。
需要说明的是,归档配置文件和定时器配置文件配置完成后,需要开启归档和定时器。具体可以通过归档开关参数来开启或关闭归档,例如将参数设置为0表示关闭归档,将参数设置为1表示开启归档,开启归档后,订阅备库上会启动一个订阅线程来进行主备之间的数据同步任务。同样也可以通过定时器开关参数来开启或关闭定时器,例如将参数设置为0表示关闭定时器,将参数设置为1表示开启定时器,开启定时器后,订阅备库上会启动一个定时器线程,该线程控制定时器的定时触发。
在一个具体的例子中,预先在订阅备库中配置INI参数文件、定时器配置文件以及归档配置文件,读取INI参数文件、定时器配置文件以及归档配置文件,若INI参数文件包括:开启归档参数和开启定时器参数,则当所述归档配置文件中的目标定时器触发时,根据归档配置文件中的主库连接信息建立与订阅主库之间的连接。例如可以是,若INI参数文件包括(1,1),则确定开启归档、开启定时器,当归档配置文件中的目标定时器触发时,根据归档配置文件中的主库连接信息建立与订阅主库之间的连接。
需要说明的是,订阅主库可以是单节点数据库,也可以是数据库集群(即多个数据库节点构成的数据库系统,多个节点可以同时访问、操作同一数据库,其中任意节点故障时,数据库均能正常对外提供服务)。若订阅主库为数据库集群,指定主库连接信息时,可以指定集群中全部或部分节点连接信息,订阅备库连接订阅主库时会自动从中选择一个有效节点进行连接。其中,选取有效节点的方式可以为:获取集群中全部或部分节点的状态信息,根据集群中全部或部分节点的状态信息选取目标节点,所述目标节点为归档有效节点。
S120,获取目标LSN值,并根据所述目标LSN值生成同步请求指令,并将所述同步请求指令发送至订阅主库。
其中,LSN(Log Sequence Number)是由数据库系统自动维护的整数型数值,全局递增,每一个LSN值代表着数据库系统内部产生的一个物理事务。归档日志文件中的每一条日志均对应一个物理事务,即对应一个LSN值。
其中,所述同步请求指令携带目标LSN值,所述同步请求指令还可以携带订阅备库的标识信息。
具体的,获取目标LSN值,并根据所述目标LSN值生成同步请求指令,并将所述同步请求指令发送至订阅主库的方式可以为:订阅备库获取归档配置文件中的归档目录对应的最大LSN值,并将归档目录对应的最大LSN值确定为目标LSN值,订阅备库根据目标LSN值生成同步请求指令,并将同步请求指令发送至订阅主库,订阅主库在接收到同步请求指令后,根据同步请求指令携带的目标LSN值获取目标归档日志文件。
S130,接收订阅主库发送的所述目标LSN值对应的目标归档日志文件。
具体的,在订阅主库接收到订阅备库发送的同步请求指令之后,订阅主库根据同步请求指令携带的目标LSN值查询得到目标归档日志文件,并将目标归档日志文件发送至同步请求指令携带的订阅备库的标识信息对应的订阅备库,订阅备库接收订阅主库发送的目标LSN值对应的目标归档日志文件。
S140,根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步。
其中,所述订阅模式可以包括:归档模式、重演模式以及归档并重演模式,其中,归档模式为仅进行归档操作的模式,重演模式为仅进行重演操作的模式,归档并重演模式为既归档,又重演的模式。
其中,所述数据同步可以指代将目标归档日志文件存储至归档配置文件的归档目录中,所述数据同步还可以指代重演所述目标归档日志文件,所述数据同步还可以指代将所述目标归档日志文件存储至归档配置文件的归档目录中,并重演所述目标归档日志文件。
具体的,根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步的方式可以为:当处于归档模式时,若目标归档日志文件校验通过,则将所述目标归档日志文件存储至归档配置文件的归档目录中。根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步的方式还可以为:当处于重演模式时,若目标归档日志文件校验通过,则重演所述目标归档日志文件。根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步的方式还可以为:当处于归档并重演模式时,若目标归档日志文件校验通过,则将所述目标归档日志文件存储至归档配置文件的归档目录中,重演所述目标归档日志文件。
在一个具体的例子中,数据同步流程如下:当归档配置文件中的目标定时器触发时,订阅备库的订阅线程启动新一轮数据同步;订阅备库解析归档配置文件,得到主库连接信息,首先根据主库连接信息依次尝试连接各节点,选择其中任意一个有效节点(非故障节点)建立最终连接进行数据同步,建立连接时直接调用数据库驱动接口(数据库驱动用于连接、操作数据库,目前常用的有DPI驱动、JDBC驱动等)即可。连接建立后,订阅备库和订阅主库之间便可直接通过该连接进行交互;订阅备库根据本地归档日志文件中的最大LSN值(可以扫描一遍归档目录中的归档日志文件,然后确定其中的最大LSN值),向订阅主库节点发起同步请求;订阅主库收到同步请求后,向订阅备库(请求发起者)发送目标归档日志文件。订阅备库接收到目标归档日志文件后,根据归档配置文件中指定的订阅模式和目标归档日志文件进行数据同步。
可选的,根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步,包括:
当处于归档模式时,获取归档配置文件中的归档目录对应的最大LSN值;
根据获取归档配置文件中的归档目录对应的最大LSN值对所述目标归档日志文件进行校验;
若校验通过,则将所述目标归档日志文件存储至归档配置文件的归档目录中。
具体的,根据获取归档配置文件中的归档目录对应的最大LSN值对所述目标归档日志文件进行校验的方式可以为:判断目标归档日志文件对应的LSN值和归档配置文件中的归档目录对应的归档日志文件中的最大LSN值的差值是否等于设定阈值,若是,则确定校验通过,若否,则确定校验不通过,其中,所述设定阈值可以为1,也可以为其他数值,本发明实施例对此不进行限制。
需要说明的是,对目标归档日志文件进行校验的目的是为了保证LSN值的连续性。
可选的,还包括:
获取重演指令,其中,所述重演指令包括:LSN值区间;
对LSN值区间内的所有归档日志文件进行重演。
其中,所述LSN值区间可以根据数据库系统过程SP_A确定,例如可以是,根据数据库系统过程SP_A的参数确定LSN值区间对应的最小LSN值和最大LSN值。
具体的,对LSN值区间内的所有归档日志文件进行重演的方式可以为:按照预设顺序依次重演LSN值区间内的所有归档日志文件。例如可以是,按照LSN值区间内的LSN值从小到大的顺序依次重演LSN值区间内的归档日志文件。
需要说明的是,当处于归档模式时,可以手动重演归档日志文件:可以通过数据库系统过程实现重演归档日志文件,例如可以是:实现数据库系统过程SP_A,用户可以通过指定LSN值范围来手动重演归档日志。在一个具体的例子中,执行SP_A(10000,11000)即可立即重演LSN值在10000到11000范围内的所有归档日志文件。
在一个具体的例子中,当处于归档模式时,订阅备库将获取到的目标归档日志文件保存到归档目录中,不进行重演,用户可以选择在适当时机手动重演归档日志。归档模式可以有效解决异步主备系统中,备库日志重演速度赶不上主库日志产生速度的问题。归档模式下,订阅备库获取目标归档日志文件后,会根据归档配置文件中的归档目录对应的最大LSN值对获取的目标归档日志文件进行校验,进而保证LSN值的连续性。
可选的,根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步,包括:
当处于重演模式时,获取当前重演成功的归档日志文件对应的LSN值;
根据当前重演成功的归档日志文件对应的LSN值对所述目标归档日志文件进行校验;
若校验通过,则重演所述目标归档日志文件。
需要说明的是,当处于重演模式时,订阅备库获取到归档日志文件后,直接重演目标归档日志文件,不将其保存到归档目录中。
具体的,根据当前重演成功的归档日志文件对应的LSN值对所述目标归档日志文件进行校验的方式可以为:判断目标归档日志文件对应的LSN值和当前重演成功的归档日志文件对应的LSN值的差值是否等于设定阈值,若是,则确定校验通过,若否,则确定校验不通过,其中,所述设定阈值可以为1,也可以为其他数值,本发明实施例对此不进行限制。
可选的,根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步,包括:
当处于归档并重演模式时,获取当前重演成功的归档日志文件对应的LSN值;
根据当前重演成功的归档日志文件对应的LSN值对所述目标归档日志文件进行校验;
若校验通过,则将所述目标归档日志文件存储至归档配置文件的归档目录中;
重演所述目标归档日志文件。
需要说明的是,归档并重演模式:订阅备库将获取到的目标归档日志文件保存到归档目录中,并重演目标归档日志文件。订阅备库每次重演日志完成后,会记录当前重演日志的最大LSN值(当前重演日志的最大LSN值也就是当前重演成功的归档日志文件对应的LSN值),在仅重演、归档并重演模式下,订阅备库获取归档日志文件后,会根据上述重演的最大LSN值,对获取的归档日志文件进行校验,保证LSN值的连续性。
除上述内容之外,本发明实施例还支持在归档配置文件中设置限流参数,控制订阅备库每秒获取的最大归档日志量,以此来降低数据同步工作对订阅主库性能的影响。
另外,订阅备库将归档日志文件保存到归档目录或者重演归档日志的同时,可以并行执行归档日志文件获取的动作。
实施例二
图2为本发明实施例提供的一种数据同步方法的流程图,本实施例可适用于数据同步的情况,该方法可以由本发明实施例中配置在订阅主库中的数据同步装置来执行,该装置可采用软件和/或硬件的方式实现,如图2所示,该方法具体包括如下步骤:
S210,接收订阅备库发送的同步请求指令,其中,所述同步请求指令携带目标LSN值。
其中,LSN(Log Sequence Number)是由数据库系统自动维护的整数型数值,全局递增,每一个LSN值代表着数据库系统内部产生的一个物理事务。归档日志文件中的每一条日志均对应一个物理事务,即对应一个LSN值。
其中,所述目标LSN值为订阅备库中的归档配置文件中的归档目录对应的最大LSN值。
需要说明的是,所述同步请求指令携带订阅备库标识信息,以使得订阅主库可以将目标归档日志文件对应发送至目标订阅备库,其中,所述目标订阅备库为发送同步请求指令的订阅备库。也就是说,在订阅备库存在至少两个的情况下,订阅备库向订阅主库发送的同步请求指令需要携带发送请求的订阅备库的标识信息,以便于订阅主库反馈目标归档日志文件至发送请求的订阅备库。能够提升订阅主库和订阅备库数据交互的准确性。
S220,获取所述目标LSN值对应的目标归档日志文件。
其中,所述目标归档日志文件的LSN值可以与所述目标LSN值相同,也可以与所述目标LSN值的差值等于设定阈值,本发明实施例对此不进行限制。
需要说明的是,若目标归档日志文件的LSN值与所述目标LSN值相同,则可以减少订阅主库处理的数据,提升订阅主库的处理效果。
S230,将所述目标LSN值对应的目标归档日志文件发送至所述订阅备库,以使所述订阅备库根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步。
具体的,订阅主库将所述目标LSN值对应的目标归档日志文件发送至所述订阅备库,订阅备库根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步。其中,订阅备库根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步的方式可以为:当处于归档模式时,获取归档配置文件中的归档目录对应的最大LSN值;根据获取归档配置文件中的归档目录对应的最大LSN值对所述目标归档日志文件进行校验;若校验通过,则将所述目标归档日志文件存储至归档配置文件的归档目录中。当处于归档模式时,还可以手动重演归档日志,具体的方式为:获取重演指令,其中,所述重演指令包括:LSN值区间;对LSN值区间内的所有归档日志文件进行重演。根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步的方式还可以为:当处于重演模式时,获取当前重演成功的归档日志文件对应的LSN值;根据当前重演成功的归档日志文件对应的LSN值对所述目标归档日志文件进行校验;若校验通过,则重演所述目标归档日志文件。根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步的方式还可以为:当处于归档并重演模式时,获取当前重演成功的归档日志文件对应的LSN值;根据当前重演成功的归档日志文件对应的LSN值对所述目标归档日志文件进行校验;若校验通过,则将所述目标归档日志文件存储至归档配置文件的归档目录中;重演所述目标归档日志文件。
本实施例的技术方案,将归档配置文件仅在订阅备库上进行配置,并且订阅主库和订阅备库之间不依赖通讯模块进行通讯,订阅主库通过接收订阅备库发送的同步请求指令,其中,所述同步请求指令携带目标LSN值;获取所述目标LSN值对应的目标归档日志文件;将所述目标LSN值对应的目标归档日志文件发送至所述订阅备库,以使所述订阅备库根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步。能够解决由于主库产生的归档日志较多,造成备库的日志重演速度赶不上主库的日志产生速度,进而导致主备系统出现异常的问题,能够提升订阅备库的独立性和订阅主库配置的灵活性,并且能够保证订阅主库连续对外提供服务。
实施例三
图3为本发明实施例提供的一种数据同步装置的结构示意图。本实施例可适用于数据同步的情况,该装置可采用软件和/或硬件的方式实现,该装置可集成在任何提供数据同步功能的设备中,如图3所示,所述数据同步装置具体包括:连接建立模块310、同步请求指令发送模块320、归档日志文件接收模块330和数据同步模块340。
其中,连接建立模块,用于当归档配置文件中的目标定时器触发时,根据归档配置文件中的主库连接信息建立与订阅主库之间的连接;
同步请求指令发送模块,用于获取目标LSN值,并根据所述目标LSN值生成同步请求指令,并将所述同步请求指令发送至订阅主库;
归档日志文件接收模块,用于接收订阅主库发送的所述目标LSN值对应的目标归档日志文件;
数据同步模块,用于根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步。
上述产品可执行本发明任意实施例所提供的方法,具备执行方法相应的功能模块和有益效果。
实施例四
图4为本发明实施例提供的一种数据同步装置的结构示意图。本实施例可适用于数据同步的情况,该装置可采用软件和/或硬件的方式实现,该装置可集成在任何提供数据同步功能的设备中,如图4所示,所述数据同步装置具体包括:同步请求指令接收模块410、目标归档日志文件获取模块420和目标归档日志文件发送模块430。
其中,同步请求指令接收模块,用于接收订阅备库发送的同步请求指令,其中,所述同步请求指令携带目标LSN值;
目标归档日志文件获取模块,用于获取所述目标LSN值对应的目标归档日志文件;
目标归档日志文件发送模块,用于将所述目标LSN值对应的目标归档日志文件发送至所述订阅备库,以使所述订阅备库根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步。
上述产品可执行本发明任意实施例所提供的方法,具备执行方法相应的功能模块和有益效果。
实施例五
图5示出了可以用来实施本发明的实施例的电子设备10的结构示意图。电子设备旨在表示各种形式的数字计算机,诸如,膝上型计算机、台式计算机、工作台、个人数字助理、服务器、刀片式服务器、大型计算机、和其它适合的计算机。电子设备还可以表示各种形式的移动装置,诸如,个人数字处理、蜂窝电话、智能电话、可穿戴设备(如头盔、眼镜、手表等)和其它类似的计算装置。本文所示的部件、它们的连接和关系、以及它们的功能仅仅作为示例,并且不意在限制本文中描述的和/或者要求的本发明的实现。
如图5所示,电子设备10包括至少一个处理器11,以及与至少一个处理器11通信连接的存储器,如只读存储器(ROM)12、随机访问存储器(RAM)13等,其中,存储器存储有可被至少一个处理器执行的计算机程序,处理器11可以根据存储在只读存储器(ROM)12中的计算机程序或者从存储单元18加载到随机访问存储器(RAM)13中的计算机程序,来执行各种适当的动作和处理。在RAM 13中,还可存储电子设备10操作所需的各种程序和数据。处理器11、ROM 12以及RAM 13通过总线14彼此相连。输入/输出(I/O)接口15也连接至总线14。
电子设备10中的多个部件连接至I/O接口15,包括:输入单元16,例如键盘、鼠标等;输出单元17,例如各种类型的显示器、扬声器等;存储单元18,例如磁盘、光盘等;以及通信单元19,例如网卡、调制解调器、无线通信收发机等。通信单元19允许电子设备10通过诸如因特网的计算机网络和/或各种电信网络与其他设备交换信息/数据。
处理器11可以是各种具有处理和计算能力的通用和/或专用处理组件。处理器11的一些示例包括但不限于中央处理单元(CPU)、图形处理单元(GPU)、各种专用的人工智能(AI)计算芯片、各种运行机器学习模型算法的处理器、数字信号处理器(DSP)、以及任何适当的处理器、控制器、微控制器等。处理器11执行上文所描述的各个方法和处理,例如数据同步方法。
在一些实施例中,数据同步方法可被实现为计算机程序,其被有形地包含于计算机可读存储介质,例如存储单元18。在一些实施例中,计算机程序的部分或者全部可以经由ROM 12和/或通信单元19而被载入和/或安装到电子设备10上。当计算机程序加载到RAM 13并由处理器11执行时,可以执行上文描述的数据同步方法的一个或多个步骤。备选地,在其他实施例中,处理器11可以通过其他任何适当的方式(例如,借助于固件)而被配置为执行数据同步方法。
本文中以上描述的系统和技术的各种实施方式可以在数字电子电路系统、集成电路系统、场可编程门阵列(FPGA)、专用集成电路(ASIC)、专用标准产品(ASSP)、芯片上系统的系统(SOC)、负载可编程逻辑设备(CPLD)、计算机硬件、固件、软件、和/或它们的组合中实现。这些各种实施方式可以包括:实施在一个或者多个计算机程序中,该一个或者多个计算机程序可在包括至少一个可编程处理器的可编程系统上执行和/或解释,该可编程处理器可以是专用或者通用可编程处理器,可以从存储系统、至少一个输入装置、和至少一个输出装置接收数据和指令,并且将数据和指令传输至该存储系统、该至少一个输入装置、和该至少一个输出装置。
用于实施本发明的方法的计算机程序可以采用一个或多个编程语言的任何组合来编写。这些计算机程序可以提供给通用计算机、专用计算机或其他可编程数据处理装置的处理器,使得计算机程序当由处理器执行时使流程图和/或框图中所规定的功能/操作被实施。计算机程序可以完全在机器上执行、部分地在机器上执行,作为独立软件包部分地在机器上执行且部分地在远程机器上执行或完全在远程机器或服务器上执行。
在本发明的上下文中,计算机可读存储介质可以是有形的介质,其可以包含或存储以供指令执行系统、装置或设备使用或与指令执行系统、装置或设备结合地使用的计算机程序。计算机可读存储介质可以包括但不限于电子的、磁性的、光学的、电磁的、红外的、或半导体系统、装置或设备,或者上述内容的任何合适组合。备选地,计算机可读存储介质可以是机器可读信号介质。机器可读存储介质的更具体示例会包括基于一个或多个线的电气连接、便携式计算机盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦除可编程只读存储器(EPROM或快闪存储器)、光纤、便捷式紧凑盘只读存储器(CD-ROM)、光学储存设备、磁储存设备、或上述内容的任何合适组合。
为了提供与用户的交互,可以在电子设备上实施此处描述的系统和技术,该电子设备具有:用于向用户显示信息的显示装置(例如,CRT(阴极射线管)或者LCD(液晶显示器)监视器);以及键盘和指向装置(例如,鼠标或者轨迹球),用户可以通过该键盘和该指向装置来将输入提供给电子设备。其它种类的装置还可以用于提供与用户的交互;例如,提供给用户的反馈可以是任何形式的传感反馈(例如,视觉反馈、听觉反馈、或者触觉反馈);并且可以用任何形式(包括声输入、语音输入或者、触觉输入)来接收来自用户的输入。
可以将此处描述的系统和技术实施在包括后台部件的计算系统(例如,作为数据服务器)、或者包括中间件部件的计算系统(例如,应用服务器)、或者包括前端部件的计算系统(例如,具有图形用户界面或者网络浏览器的用户计算机,用户可以通过该图形用户界面或者该网络浏览器来与此处描述的系统和技术的实施方式交互)、或者包括这种后台部件、中间件部件、或者前端部件的任何组合的计算系统中。可以通过任何形式或者介质的数字数据通信(例如,通信网络)来将系统的部件相互连接。通信网络的示例包括:局域网(LAN)、广域网(WAN)、区块链网络和互联网。
计算系统可以包括客户端和服务器。客户端和服务器一般远离彼此并且通常通过通信网络进行交互。通过在相应的计算机上运行并且彼此具有客户端-服务器关系的计算机程序来产生客户端和服务器的关系。服务器可以是云服务器,又称为云计算服务器或云主机,是云计算服务体系中的一项主机产品,以解决了传统物理主机与VPS服务中,存在的管理难度大,业务扩展性弱的缺陷。
应该理解,可以使用上面所示的各种形式的流程,重新排序、增加或删除步骤。例如,本发明中记载的各步骤可以并行地执行也可以顺序地执行也可以不同的次序执行,只要能够实现本发明的技术方案所期望的结果,本文在此不进行限制。
上述具体实施方式,并不构成对本发明保护范围的限制。本领域技术人员应该明白的是,根据设计要求和其他因素,可以进行各种修改、组合、子组合和替代。任何在本发明的精神和原则之内所作的修改、等同替换和改进等,均应包含在本发明保护范围之内。

Claims (10)

1.一种数据同步方法,其特征在于,应用于数据库,所述数据库包括:订阅主库和订阅备库,其中,所述订阅备库中配置有归档配置文件,所述数据同步方法由订阅备库执行,所述数据同步方法包括:
当所述归档配置文件中的目标定时器触发时,根据归档配置文件中的主库连接信息建立与订阅主库之间的连接;
获取目标LSN值,并根据所述目标LSN值生成同步请求指令,并将所述同步请求指令发送至订阅主库;
接收订阅主库发送的所述目标LSN值对应的目标归档日志文件;
根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步。
2.根据权利要求1所述的方法,其特征在于,根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步,包括:
当处于归档模式时,获取归档配置文件中的归档目录对应的最大LSN值;
根据获取归档配置文件中的归档目录对应的最大LSN值对所述目标归档日志文件进行校验;
若校验通过,则将所述目标归档日志文件存储至归档配置文件的归档目录中。
3.根据权利要求2所述的方法,其特征在于,还包括:
获取重演指令,其中,所述重演指令包括:LSN值区间;
对LSN值区间内的所有归档日志文件进行重演。
4.根据权利要求1所述的方法,其特征在于,根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步,包括:
当处于重演模式时,获取当前重演成功的归档日志文件对应的LSN值;
根据当前重演成功的归档日志文件对应的LSN值对所述目标归档日志文件进行校验;
若校验通过,则重演所述目标归档日志文件。
5.根据权利要求1所述的方法,其特征在于,根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步,包括:
当处于归档并重演模式时,获取当前重演成功的归档日志文件对应的LSN值;
根据当前重演成功的归档日志文件对应的LSN值对所述目标归档日志文件进行校验;
若校验通过,则将所述目标归档日志文件存储至归档配置文件的归档目录中;
重演所述目标归档日志文件。
6.一种数据同步方法,其特征在于,由订阅主库执行,所述数据同步方法包括:
接收订阅备库发送的同步请求指令,其中,所述同步请求指令携带目标LSN值;
获取所述目标LSN值对应的目标归档日志文件;
将所述目标LSN值对应的目标归档日志文件发送至所述订阅备库,以使所述订阅备库根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步。
7.一种数据同步装置,其特征在于,所述数据同步装置包括:
连接建立模块,用于当归档配置文件中的目标定时器触发时,根据归档配置文件中的主库连接信息建立与订阅主库之间的连接;
同步请求指令发送模块,用于获取目标LSN值,并根据所述目标LSN值生成同步请求指令,并将所述同步请求指令发送至订阅主库;
归档日志文件接收模块,用于接收订阅主库发送的所述目标LSN值对应的目标归档日志文件;
数据同步模块,用于根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步。
8.一种数据同步装置,其特征在于,所述数据同步装置包括:
同步请求指令接收模块,用于接收订阅备库发送的同步请求指令,其中,所述同步请求指令携带目标LSN值;
目标归档日志文件获取模块,用于获取所述目标LSN值对应的目标归档日志文件;
目标归档日志文件发送模块,用于将所述目标LSN值对应的目标归档日志文件发送至所述订阅备库,以使所述订阅备库根据归档配置文件中的订阅模式和所述目标归档日志文件进行数据同步。
9.一种电子设备,其特征在于,所述电子设备包括:
至少一个处理器;以及
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的计算机程序,所述计算机程序被所述至少一个处理器执行,以使所述至少一个处理器能够执行权利要求1-6中任一项所述的数据同步方法。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质存储有计算机指令,所述计算机指令用于使处理器执行时实现权利要求1-6中任一项所述的数据同步方法。
CN202310861300.8A 2023-07-13 2023-07-13 一种数据同步方法、装置、设备及存储介质 Pending CN116821247A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202310861300.8A CN116821247A (zh) 2023-07-13 2023-07-13 一种数据同步方法、装置、设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202310861300.8A CN116821247A (zh) 2023-07-13 2023-07-13 一种数据同步方法、装置、设备及存储介质

Publications (1)

Publication Number Publication Date
CN116821247A true CN116821247A (zh) 2023-09-29

Family

ID=88142869

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202310861300.8A Pending CN116821247A (zh) 2023-07-13 2023-07-13 一种数据同步方法、装置、设备及存储介质

Country Status (1)

Country Link
CN (1) CN116821247A (zh)

Similar Documents

Publication Publication Date Title
CN108847982B (zh) 一种分布式存储集群及其节点故障切换方法和装置
CN112769652B (zh) 一种节点服务监控方法、装置、设备及介质
CN111541762B (zh) 数据处理的方法、管理服务器、设备及存储介质
CN109558209B (zh) 一种用于虚拟机的监控方法
CN114528350A (zh) 集群脑裂的处理方法、装置、设备及可读存储介质
CN113703946A (zh) 应用恢复方法及其装置、电子设备、计算机可读存储介质
CN113765690A (zh) 集群切换方法、系统、装置、终端、服务器及存储介质
CN116821247A (zh) 一种数据同步方法、装置、设备及存储介质
CN115314361A (zh) 一种服务器集群管理方法及其相关组件
CN114691781A (zh) 一种数据同步方法、系统、装置、设备及介质
CN113420275A (zh) 数据连接处理方法、相关装置及计算机程序产品
CN115174447B (zh) 一种网络通信方法、装置、系统、设备及存储介质
CN117395263B (zh) 一种数据同步方法、装置、设备和存储介质
CN114513524B (zh) 一种资源同步方法、装置、电子设备和存储介质
CN113138881B (zh) 分布式文件系统备份方法、装置和系统
CN116991635B (zh) 数据同步方法和数据同步装置
CN115981879B (zh) 一种冗余结构的数据同步方法、装置、设备及存储介质
CN113660339B (zh) 用于去中心化集群的方法和装置
CN117234779A (zh) 一种分布式数据库的异常恢复方法、装置、设备及介质
CN118012700A (zh) 异构设备管理方法、服务端、设备及介质
CN115422129A (zh) 一种会话处理方法、装置、电子设备及存储介质
CN117112695A (zh) 一种数据库同步方法、装置、电子设备和存储介质
CN115865734A (zh) 一种故障检测方法、数据生成方法、装置、设备及介质
CN115905406A (zh) 基于嵌入式数据库的数据同步方法、装置、设备及介质
CN117675841A (zh) 一种配置信息同步方法、系统、电子设备及存储介质

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