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

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

Info

Publication number
CN117668114A
CN117668114A CN202311667144.8A CN202311667144A CN117668114A CN 117668114 A CN117668114 A CN 117668114A CN 202311667144 A CN202311667144 A CN 202311667144A CN 117668114 A CN117668114 A CN 117668114A
Authority
CN
China
Prior art keywords
synchronous
data
synchronization
task
tasks
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
CN202311667144.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.)
Agricultural Bank of China
Original Assignee
Agricultural Bank of China
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 Agricultural Bank of China filed Critical Agricultural Bank of China
Priority to CN202311667144.8A priority Critical patent/CN117668114A/zh
Publication of CN117668114A publication Critical patent/CN117668114A/zh
Pending legal-status Critical Current

Links

Landscapes

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

Abstract

本发明公开了一种数据同步方法、装置、设备及介质,涉及数据库同步技术领域。包括:通过数据同步模块,接收到产品的更新数据,将更新数据存储至第一数据库中,并对更新数据进行数据转换,得到产品的同步数据;通过数据同步模块,为产品的同步数据生成目标同步任务,并向同步任务处理器发送目标同步任务;通过同步任务处理模块,接收到目标同步任务,根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和正在执行同步任务的同步服务器的运行状态参数,确定目标同步任务的执行服务器;通过同步任务处理模块,将目标同步任务发送给执行服务器,以使执行服务器将同步数据存储至第二数据库。本方案提高了异构数据库之间的数据同步效率。

Description

一种数据同步方法、装置、设备及介质
技术领域
本发明涉及数据库同步技术领域,尤其涉及一种数据同步方法、装置、设备及介质。
背景技术
对于业务人员来说,通常更关心产品的效果、使用量和受欢迎程度等产品本身的属性;对于技术人员来说,通常更关心产品的签约过程和结算过程等与其他系统之间交互的状态参数,因此,第二数据库与第一数据库之间的数据存储形式通常不同。
为了保证不同系统的数据库之中产品数据的一致性,通常以人工审批流程的形式完成不同系统间产品数据的同步,数据结构变更较多,不同系统之间的人员需要进行沟通,导致产品数据的同步效率偏低。
发明内容
本发明提供了一种数据同步方法、装置、设备及介质,以实现异构数据库之间的数据同步,以及提高数据同步的效率。
第一方面,本发明提供了一种数据同步方法,包括:
通过数据同步模块,接收到产品的更新数据,将更新数据存储至第一数据库中,并对更新数据进行数据转换,得到产品的同步数据;
通过数据同步模块,为产品的同步数据生成目标同步任务,并向同步任务处理器发送目标同步任务;
通过同步任务处理模块,接收到目标同步任务,根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和正在执行同步任务的同步服务器的运行状态参数,确定目标同步任务的执行服务器;
通过同步任务处理模块,将目标同步任务发送给执行服务器,以使执行服务器将同步数据存储至第二数据库中。
第二方面,本发明还提供了一种数据同步装置,包括:
数据转换模块,用于通过数据同步模块,接收到产品的更新数据,将更新数据存储至第一数据库中,并对更新数据进行数据转换,得到产品的同步数据;
任务生成模块,用于通过数据同步模块,为产品的同步数据生成目标同步任务,并向同步任务处理器发送目标同步任务;
服务器确定模块,用于通过同步任务处理模块,接收到目标同步任务,根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和正在执行同步任务的同步服务器的运行状态参数,确定目标同步任务的执行服务器;
任务发送模块,用于通过同步任务处理模块,将目标同步任务发送给执行服务器,以使执行服务器将同步数据存储至第二数据库中。
第三方面,本发明实施例还提供了一种电子设备,包括:
至少一个处理器;以及
与至少一个处理器通信连接的存储器;其中
存储器存储有可被至少一个处理器执行的指令,指令被至少一个处理器执行,以使至少一个处理器能够执行本发明任一实施例所提供的数据同步方法。
第四方面,本发明实施例还提供了一种计算机可读存储介质,计算机可读存储介质存储有计算机指令,计算机指令用于使处理器执行时实现本发明任一实施例所提供的数据同步方法。
本发明实施例通过数据同步模块,接收到产品的更新数据,将更新数据存储至第一数据库中,并对更新数据进行数据转换,得到产品的同步数据;通过数据同步模块,为产品的同步数据生成目标同步任务,并向同步任务处理器发送目标同步任务;通过同步任务处理模块,接收到目标同步任务,根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和正在执行同步任务的同步服务器的运行状态参数,确定目标同步任务的执行服务器;通过同步任务处理模块,将目标同步任务发送给执行服务器,以使执行服务器将同步数据存储至第二数据库中。本发明实施例的技术方案,通过将更新数据存储至第一数据库,并对更新数据进行数据转换,将得到的同步数据存储至数据库中,可以实现异构数据库之间的数据同步;并且为同步数据生成目标同步任务,并确定目标同步任务的执行服务器,以使执行服务器将同步数据存储至第二数据库中,提高了数据的同步效率。
应当理解,本部分所描述的内容并非旨在标识本发明的实施例的关键或重要特征,也不用于限制本发明的范围。本发明的其它特征将通过以下的说明书而变得容易理解。
附图说明
为了更清楚地说明本发明实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是根据本发明实施例一提供的一种数据同步方法的流程图;
图2是根据本发明实施例二提供的一种数据同步方法的流程图;
图3A是根据本发明实施例三提供的一种数据同步方法的流程图;
图3B是根据本发明实施例三提供的一种数据同步系统的结构示意图;
图3C是根据本发明实施例三提供的另一种数据同步系统的结构示意图;
图4是根据本发明实施例四提供的一种数据同步装置的结构示意图;
图5是实现本发明实施例的数据同步方法的电子设备的结构示意图。
具体实施方式
为了使本技术领域的人员更好地理解本发明方案,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分的实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都应当属于本发明保护的范围。
需要说明的是,本发明的说明书和权利要求书及上述附图中的术语“第一”和“第二”等是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的本发明的实施例能够以除了在这里图示或描述的那些以外的顺序实施。此外,术语“包括”和“具有”以及他们的任何变形,意图在于覆盖不排他的包含,例如,包含了一系列步骤或单元的过程、方法、系统、产品或设备不必限于清楚地列出的那些步骤或单元,而是可包括没有清楚地列出的或对于这些过程、方法、产品或设备固有的其它步骤或单元。
本发明实施例的技术方案中,所涉及的更新数据等的获取、存储和应用等,均符合相关法律法规的规定,且不违背公序良俗。
实施例一
图1为本发明实施例一提供的一种数据同步方法的流程图,本实施例可适用于对数据进行同步的情况,该方法可以由一种数据同步装置来执行,该数据同步装置可以采用硬件和/或软件的形式实现,并具体配置于电子设备中,例如服务器中。
参见图1所示的数据同步方法,包括:
S101、通过数据同步模块,接收到产品的更新数据,将更新数据存储至第一数据库中,并对更新数据进行数据转换,得到产品的同步数据。
本实施例中,数据同步模块可以是用于接收并在第一数据库中存储更新数据,以及为更新数据生成同步任务的模块。更新数据可以是产品的待更新的数据。同步数据可以是产品的待存储至第二数据库的数据。其中,第一数据库的数据结构和第二数据库的数据结构不同。
具体的,通过数据同步模块,接收到产品的更新数据,将更新数据存储至第一数据库中;并采用一定的算法,对更新数据进行数据转换,得到产品的同步数据。
可选的,对更新数据进行数据转换,得到产品的同步数据,包括:根据预设的数据转换配置信息和更新数据,对更新数据进行数据转换,得到转换数据;根据产品的标识信息,从转换数据去除标识信息对应的操作执行过程数据,得到同步数据;同步数据包括属性数据。
其中,数据转换配置信息中预设有更新数据与转换数据之间的字段名映射关系,以及更新数据与转换数据之间的字段值映射关系;数据转换配置信息可以由技术人员根据实际需求或实践经验自主设定,本发明对此不做限定。转换数据可以是经过数据转换后的更新数据。产品的标识信息可以用于唯一标识对应的产品;操作执行过程数据可以是执行与产品相关操作的过程中的数据,例如可以包括操作响应时长、操作执行延迟和操作成功率等。属性数据可以是产品本身的属性的数据,用于表征产品的属性。示例性的,若产品为资源,则产品的属性数据可以包括但不限于资源名称、资源量和资源有效期等;与资源相关的操作可以包括但不限于资源名称修改操作、资源量调整操作和资源有效期修改操作等。
在一个具体实施例中,第一数据库可以是产品管理系统的数据库、第二数据库可以是技术管理系统的数据库;产品管理系统是面向产品开发人员的系统;业务管理系统的数据库中存储产品的属性数据;技术管理系统是面向操作管理人员的系统;技术管理系统的数据库中存储产品的属性数据和产品的操作执行过程数据。
具体的,根据预设的数据转换配置信息,对更新数据中的至少一个字段的字段名和字段值进行转换,得到转换数据;根据产品的标识信息查询标识信息对应的至少一个操作执行过程字段;从转换数据去除各操作执行过程字段的数据,得到同步数据。
可以理解的是,采用上述技术方案,可以将与第一数据库的数据结构相同的更新数据转换为与第二数据库的数据结构相同的同步数据,实现了异构数据库之间的数据转换;从转换数据中去除操作执行过程数据,能够将第一数据库中无需存储的数据去除,进而降低了数据同步量,提高了数据的同步效率。
在一个可选实施例中,预设的数据转换配置信息中配置有更新数据中产品的层级字段与转换数据中产品的层级字段之间的映射关系;其中,层级字段可以理解为表征产品的层级结构的字段;层级字段的字段值可以用于表征产品在对应层级中的具体类别;产品在更新数据中的层级字段与在转换数据中的层级字段不同,也即产品在更新数据中的层级结构与产品在转换数据中的层级结构不同;例如,更新数据中的各层级字段可以依次表征产品所属的行政区域;转换数据中的各层级字段表征可以依次表征产品的类型。
S102、通过数据同步模块,为产品的同步数据生成目标同步任务,并向同步任务处理器发送目标同步任务。
本实施例中,目标同步任务可以是将同步数据存储至第二数据库的任务。同步任务处理器可以用于确定目标同步任务的执行服务器,并将目标同步任务发送给执行服务器,以使执行服务器将同步数据存储至第二数据库中。需要说明的是,本发明对任务生成方式和任务发送方式不做限定,可以采用现有技术中的任一种加以实现。
S103、通过同步任务处理模块,接收到目标同步任务,根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和正在执行同步任务的同步服务器的运行状态参数,确定目标同步任务的执行服务器。
本实施例中,未完成的同步任务可以包括但不限于已经开始执行但未结束的同步任务和尚未开始执行的同步任务。同步服务器即是正在执行同步任务的服务器。运行状态参数可以包括但不限于处理器占用量、内存占用量、可用线程数量、历史同步任务的响应时长、执行历史同步任务的数据吞吐量和历史同步任务的成功率等;其中历史同步任务可以是已完成的同步任务。执行服务器可以是执行目标同步任务的服务器。
具体的,采用一定的算法,根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和正在执行同步任务的同步服务器的运行状态参数,确定目标同步任务的执行服务器。
S104、通过同步任务处理模块,将目标同步任务发送给执行服务器,以使执行服务器将同步数据存储至第二数据库中。
本发明实施例通过数据同步模块,接收到产品的更新数据,将更新数据存储至第一数据库中,并对更新数据进行数据转换,得到产品的同步数据;通过数据同步模块,为产品的同步数据生成目标同步任务,并向同步任务处理器发送目标同步任务;通过同步任务处理模块,接收到目标同步任务,根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和正在执行同步任务的同步服务器的运行状态参数,确定目标同步任务的执行服务器;通过同步任务处理模块,将目标同步任务发送给执行服务器,以使执行服务器将同步数据存储至第二数据库中。本发明实施例的技术方案,通过将更新数据存储至第一数据库,并对更新数据进行数据转换,将得到的同步数据存储至数据库中,可以实现异构数据库之间的数据同步;并且为同步数据生成目标同步任务,并确定目标同步任务的执行服务器,以使执行服务器将同步数据存储至第二数据库中,提高了数据的同步效率。
实施例二
图2为本发明实施例二提供的一种数据同步方法的流程图,本发明实施例在上述实施例的技术方案的基础上,对目标同步任务的执行服务器的确定操作进行了优化改进。
进一步地,将“根据未完成的同步任务的数量、同步服务器的数量和同步服务器的运行状态参数,确定目标同步任务的执行服务器”细化为“根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和正在执行同步任务的同步服务器的运行状态参数,对同步服务器集群进行更新,得到更新后的正在执行同步任务的同步服务器集群;同步服务器集群包括正在执行同步任务的同步服务器;从更新后的正在执行同步任务的同步服务器集群中确定目标同步任务的执行服务器”,以完善目标同步任务的执行服务器的确定操作。
需要说明的是,在本发明实施例中未详述部分,可参见前述实施例的表述。
参见图2所示的数据同步方法,包括:
S201、通过数据同步模块,接收到产品的更新数据,将更新数据存储至第一数据库中,并对更新数据进行数据转换,得到产品的同步数据。
S202、通过数据同步模块,为产品的同步数据生成目标同步任务,并向同步任务处理器发送目标同步任务。
S203、通过同步任务处理模块,接收到目标同步任务,根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和正在执行同步任务的同步服务器的运行状态参数,对同步服务器集群进行更新,得到更新后的正在执行同步任务的同步服务器集群;同步服务器集群包括正在执行同步任务的同步服务器。
具体的,采用一定的算法,根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和正在执行同步任务的同步服务器的运行状态参数,对同步服务器集群进行更新,得到更新后的正在执行同步任务的同步服务器集群。
可选的,根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和正在执行同步任务的同步服务器的运行状态参数,对同步服务器集群进行更新,得到更新后的正在执行同步任务的同步服务器集群;同步服务器集群包括正在执行同步任务的同步服务器,包括:根据未完成的同步任务的数量、同步服务器集群包括的同步服务器的数量和同步服务器集群包括的同步服务器的运行状态参数确定目标同步任务的任务等待时长,并校验任务等待时长是否大于预设时长阈值;若任务等待时长小于或等于预设时长阈值,则确定同步服务器集群保持不变,并作为更新后的同步服务器集群;若任务等待时长大于预设时长阈值,则选择空闲服务器添加到同步服务器集群中,并将添加后的同步服务器集群作为更新后的同步服务器集群;返回执行根据未完成的同步任务的数量、同步服务器集群包括的同步服务器的数量和同步服务器集群包括的同步服务器的运行状态参数确定目标同步任务的任务等待时长,并校验任务等待时长是否大于预设时长阈值,直至任务等待时长小于或等于预设时长阈值;获取当前更新后的同步服务器集群。
本实施例中,任务等待时长可以是从目标同步任务的任务生成时刻至目标同步任务的完成时刻之间的时长。预设时长阈值可以由技术人员根据实际需求或实践经验自主设定,本发明对此不做限定。空闲服务器可以是未执行同步任务的服务器。具体的,采用一定的算法,根据未完成的同步任务的数量、同步服务器集群包括的同步服务器的数量和同步服务器集群包括的同步服务器的运行状态参数确定目标同步任务的任务等待时长。
可以理解的是,采用上述技术方案,可以确定目标同步任务的任务等待时长;若任务等待时长大于预设时长阈值,则添加空闲服务器至同步服务器集群中;并返回确定新的任务等待时长,并再次校验,直至任务等待时长小于或等于预设时长阈值,能够保证使目标同步任务的任务等待时长小于或等于预设时长阈值,提高了任务的执行效率,进而提高了数据的同步效率。
可选的,根据未完成的同步任务的数量、同步服务器集群包括的同步服务器的数量和同步服务器集群包括的同步服务器的运行状态参数确定目标同步任务的任务等待时长,包括:根据未完成的同步任务的数量和同步服务器集群包括的同步服务器的数量,确定每一同步服务器的未完成的单位任务数量;将单位任务数量和各同步服务器的运行状态参数输入训练好的机器学习模型,得到任务等待时长。
本实施例中,单位任务数量可以是一台同步服务器的未完成的同步任务的数量。训练好的机器学习模型是用于预测任务等待时长的模型。需要说明的是,本发明对机器学习模型不做限定,例如机器学习模型可以是LightGBM(Light Gradient BoostingMachine,轻量级梯度提升机)模型、XGBoost(EXtreme Gradient Boosting,极端梯度提升)模型和CatBoost(categorical boosting,分类增强)模型等。在一个具体实施方式中,机器学习模型采用10折交叉验证的方式进行训练。
具体的,采用一定的算法,根据未完成的同步任务的数量和同步服务器集群包括的同步服务器的数量,确定每一同步服务器的未完成的单位任务数量。可以理解的是,采用上述技术方案,可以确定单位任务数量,并根据单位任务数量、各同步服务器的运行状态参数和训练好的机器学习模型,确定任务等待时长,提高了任务等待时长的准确率。
可选的,根据未完成的同步任务的数量和同步服务器集群包括的同步服务器的数量,确定每一同步服务器的未完成的单位任务数量,包括:更新未完成的同步任务的数量,得到更新后的未完成的同步任务的数量;根据更新后的未完成的同步任务的数量与同步服务器集群包括的同步服务器的数量,确定每一同步服务器的未完成的单位任务数量。
具体的,将未完成的同步任务的数量加一,得到更新后的未完成的同步任务的数量;将更新后的未完成的同步任务的数量与同步服务器集群包括的同步服务器的数量之间的比值,确定为每一同步服务器的未完成的单位任务数量。
可以理解的是,采用上述技术方案,确定更新后的未完成的同步任务的数量;根据更新后的未完成的同步任务的数量与同步服务器集群包括的同步服务器的数量,确定未完成的单位任务数量,提高了单位任务数量的准确率。
S204、通过同步任务处理模块,从更新后的正在执行同步任务的同步服务器集群中确定目标同步任务的执行服务器。
具体的,可以根据更新后的正在执行同步任务的同步服务器集群中各同步服务器的运行状态参数,从同步服务器中选取执行服务器;或随机从同步服务器集群选取一个同步服务器作为执行服务器。
S205、通过同步任务处理模块,将目标同步任务发送给执行服务器,以使执行服务器将同步数据存储至第二数据库中。
具体的,获取执行服务器的标识信息;将目标同步任务发送给标识信息所唯一表征的执行服务器。
本发明实施例根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和正在执行同步任务的同步服务器的运行状态参数,对同步服务器集群进行更新,得到更新后的正在执行同步任务的同步服务器集群;同步服务器集群包括正在执行同步任务的同步服务器;从更新后的正在执行同步任务的同步服务器集群中确定目标同步任务的执行服务器。本发明实施例的技术方案,对同步服务器集群进行更新;从更新后的同步服务器集群中确定执行服务器,提高目标同步任务的处理效率,进而提高数据的同步效率。
实施例三
图3A为本发明实施例三提供的一种数据同步方法的流程图,本发明实施例在上述实施例的技术方案的基础上,进行了追加优化
进一步地,在“通过数据同步模块,接收到产品的更新数据,将更新数据存储至第一数据库中,并对更新数据进行数据转换,得到产品的同步数据”之前,追加“通过数据获取模块,接收到产品的输入数据,将产品数据存储至第三数据库中,并对输入数据进行数据转换,得到产品的更新数据;通过数据获取模块,将产品的更新数据发送给数据同步模块”,以实现产品的更新数据的确定操作。
需要说明的是,在本发明实施例中未详述部分,可参见前述实施例的表述。
参见图3A所示的数据同步方法,包括:
S301、通过数据获取模块,接收到产品的输入数据,将产品数据存储至第三数据库中,并对输入数据进行数据转换,得到产品的更新数据。
本实施例中,数据获取模块可以是将输入数据存储至第三数据库,并向数据同步模块发送更新数据的模块。第三数据库可以是产品操作系统的数据库,产品服务系统可以是对外提供产品服务的系统。输入数据可以是产品服务系统的操作人员输入的产品数据。其中,输入数据可以是横表形式的数据表的数据。
具体的,根据预设的数据标准化映射信息和输入数据中的至少一个字段的字段名和字段值,将输入数据中的至少一个字段的字段名映射为与该字段关联的标准字段名,以及将输入数据中至少一个字段的字段值映射为与该字段的字段值格式关联的字段值格式,得到标准化数据;根据标准化数据中各字段的字段名,将标准化数据的格式由横表数据表数据转换为纵表数据表数据的格式,得到更新数据。
其中,数据标准化映射信息中配置有预设的输入数据中的至少一个字段的字段名和更新数据中的至少一个字段的字段名之间的关联关系,以及输入数据中的至少一个字段的字段值格式与更新数据中的至少一个字段的字段值格式之间的关联关系。需要说明的是,数据标准化映射信息可以由技术人员根据实际需求或实践经验自主设定,本发明对此不做限定。
S302、通过数据获取模块,将产品的更新数据发送给数据同步模块。
S303、通过数据同步模块,接收到产品的更新数据,将更新数据存储至第一数据库中,并对更新数据进行数据转换,得到产品的同步数据。
在一个可选实施例中,在将更新数据存储至第一数据库中之前,还包括:校验更新数据中各字段的字段值是否在预设取值范围中;若更新数据中存在字段的字段值不在预设取值范围中,则生成所述更新数据的错误提示信息。
S304、通过数据同步模块,为产品的同步数据生成目标同步任务,并向同步任务处理器发送目标同步任务。
S305、通过同步任务处理模块,接收到目标同步任务,根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和正在执行同步任务的同步服务器的运行状态参数,确定目标同步任务的执行服务器。
S306、通过同步任务处理模块,将目标同步任务发送给执行服务器,以使执行服务器将同步数据存储至第二数据库中。
可选的,图3B是一种数据同步系统的结构示意图。图3B所示的数据同步系统中的数据同步方向为从将数据存储至第三数据库,并由第三数据库同步至第一数据库,再由第一数据库同步至第二数据库。如图3B所示,包括数据获取模块、数据同步模块、同步任务处理器、第一数据库、第二数据库和第三数据库。
其中,数据获取模块用于接收到产品的输入数据,将产品数据存储至第三数据库中,并对输入数据进行数据转换,得到产品的更新数据;通过调用数据同步模块的接口,将更新数据发送给数据同步模块;
数据同步模块,用于接收到产品的更新数据,将更新数据存储至第一数据库中,并对更新数据进行数据转换,得到产品的同步数据;为产品的同步数据生成目标同步任务,并向同步任务处理器发送目标同步任务;
同步任务处理模块,用于接收到目标同步任务,根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和正在执行同步任务的同步服务器的运行状态参数,确定目标同步任务的执行服务器;通过同步任务处理模块,将目标同步任务发送给执行服务器,以使执行服务器将同步数据存储至第二数据库中。
可选的,图3C是另一种数据同步系统的结构示意图。图3C所示的数据同步系统中的数据同步方向为从将数据存储至第二数据库,并由第二数据库同步至第一数据库,再由第一数据库同步至第三数据库。如图3C所示,包括数据获取模块,数据同步模块、第一模块、第一数据库、第二数据库和第三数据库。
其中,第一模块用于接收到产品的第一数据,将第一数据存储至第二数据库中,并对第一数据进行数据转换,得到产品的第一转换数据;根据所述产品的标识信息,查询产品的操作执行过程数据;将操作执行过程数据添加到第一转换数据中,得到第二数据;将第二数据发送给数据同步模块;其中,产品的第一数据可以是产品服务系统的操作人员输入的产品数据;第一数据的数据结构与同步数据的数据结构相同;产品的第二数据的数据结构与更新数据的数据结构相同;
数据同步模块,用于接收到产品的第二数据,将第二数据存储至第一数据库中,并对第二数据进行数据转换,得到产品的第三数据;将产品的第三数据发送给数据获取模块;其中,第三数据的数据结构与输入数据的数据结构相同;
数据获取模块,用于接收到产品的第三数据,将第三数据存储至第三数据库中。
本发明实施例通过数据获取模块,接收到产品的输入数据,将产品数据存储至第三数据库中,并对输入数据进行数据转换,得到产品的更新数据;通过数据获取模块,将产品的更新数据发送给数据同步模块。本发明实施例的技术方案,实现了三个异构数据库之间的数据同步,无需修改各数据库中的数据处理逻辑;对于新产品的数据,可通过简单配置转换规则实现新产品的数据在三个异构数据库之间的同步,避免了反复修改数据转换规则,提高了数据同步的效率。
实施例四
图4为本发明实施例四提供的一种数据同步装置的结构示意图。本发明实施例可适用于对数据进行同步的情况,该装置可以执行数据同步方法,该数据同步装置可以采用硬件和/或软件的形式实现,该装置可配置于电子设备中,例如服务器中。
参见图4所示的数据同步装置,包括数据转换模块401、任务生成模块402、服务器确定模块403和任务发送模块404,其中,
数据转换模块401,用于通过数据同步模块,接收到产品的更新数据,将更新数据存储至第一数据库中,并对更新数据进行数据转换,得到产品的同步数据;
任务生成模块402,用于通过数据同步模块,为产品的同步数据生成目标同步任务,并向同步任务处理器发送目标同步任务;
服务器确定模块403,用于通过同步任务处理模块,接收到目标同步任务,根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和正在执行同步任务的同步服务器的运行状态参数,确定目标同步任务的执行服务器;
任务发送模块404,用于通过同步任务处理模块,将目标同步任务发送给执行服务器,以使执行服务器将同步数据存储至第二数据库中。
本发明实施例通过数据转换模块,通过数据同步模块,接收到产品的更新数据,将更新数据存储至第一数据库中,并对更新数据进行数据转换,得到产品的同步数据;通过任务生成模块,通过数据同步模块,为产品的同步数据生成目标同步任务,并向同步任务处理器发送目标同步任务;通过服务器确定模块,通过同步任务处理模块,接收到目标同步任务,根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和正在执行同步任务的同步服务器的运行状态参数,确定目标同步任务的执行服务器;通过任务发送模块,通过同步任务处理模块,将目标同步任务发送给执行服务器,以使执行服务器将同步数据存储至第二数据库中。本发明实施例的技术方案,通过将更新数据存储至第一数据库,并对更新数据进行数据转换,将得到的同步数据存储至数据库中,可以实现异构数据库之间的数据同步;并且为同步数据生成目标同步任务,并确定目标同步任务的执行服务器,以使执行服务器将同步数据存储至第二数据库中,提高了数据的同步效率。
可选的,服务器确定模块403,包括:
服务器集群更新单元,用于根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和正在执行同步任务的同步服务器的运行状态参数,对同步服务器集群进行更新,得到更新后的正在执行同步任务的同步服务器集群;同步服务器集群包括正在执行同步任务的同步服务器;
执行服务器确定单元,用于从更新后的正在执行同步任务的同步服务器集群中确定目标同步任务的执行服务器。
可选的,执行服务器确定单元,包括:
时长校验子单元,用于根据未完成的同步任务的数量、同步服务器集群包括的同步服务器的数量和同步服务器集群包括的同步服务器的运行状态参数确定目标同步任务的任务等待时长,并校验任务等待时长是否大于预设时长阈值;
第一集群确定子单元,用于若任务等待时长小于或等于预设时长阈值,则确定同步服务器集群保持不变,并作为更新后的同步服务器集群;
第二集群确定子单元,用于若任务等待时长大于预设时长阈值,则选择空闲服务器添加到同步服务器集群中,并将添加后的同步服务器集群作为更新后的同步服务器集群;
返回子单元,用于返回执行根据未完成的同步任务的数量、同步服务器集群包括的同步服务器的数量和同步服务器集群包括的同步服务器的运行状态参数确定目标同步任务的任务等待时长,并校验任务等待时长是否大于预设时长阈值,直至任务等待时长小于或等于预设时长阈值;
集群确定子单元,用于获取当前更新后的同步服务器集群。
可选的,时长校验子单元,具体用于:
根据未完成的同步任务的数量和同步服务器集群包括的同步服务器的数量,确定每一同步服务器的未完成的单位任务数量;
将单位任务数量和各同步服务器的运行状态参数输入训练好的机器学习模型,得到任务等待时长。
可选的,时长校验子单元,具体用于:
更新未完成的同步任务的数量,得到更新后的未完成的同步任务的数量;
根据更新后的未完成的同步任务的数量与同步服务器集群包括的同步服务器的数量,确定每一同步服务器的未完成的单位任务数量。
可选的,数据转换模块401,包括:
数据转换单元,用于根据预设的数据转换配置信息和更新数据,对更新数据进行数据转换,得到转换数据;
同步数据确定单元,用于根据产品的标识信息,从转换数据去除标识信息对应的操作执行过程数据,得到同步数据;同步数据包括属性数据。
可选的,该装置还包括:
数据获取模块,用于通过数据获取模块,接收到产品的输入数据,将产品数据存储至第三数据库中,并对输入数据进行数据转换,得到产品的更新数据;
数据发送模块,用于通过数据获取模块,将产品的更新数据发送给数据同步模块。
本发明实施例所提供的数据同步装置可执行本发明任意实施例所提供的数据同步方法,具备执行数据同步方法相应的功能模块和有益效果。
实施例五
图5示出了可以用来实施本发明的实施例的电子设备500的结构示意图。电子设备旨在表示各种形式的数字计算机,诸如,膝上型计算机、台式计算机、工作台、个人数字助理、服务器、刀片式服务器、大型计算机、和其它适合的计算机。电子设备还可以表示各种形式的移动装置,诸如,个人数字处理、蜂窝电话、智能电话、可穿戴设备(如头盔、眼镜、手表等)和其它类似的计算装置。本文所示的部件、它们的连接和关系、以及它们的功能仅仅作为示例,并且不意在限制本文中描述的和/或者要求的本发明的实现。
如图5所示,电子设备500包括至少一个处理器501,以及与至少一个处理器501通信连接的存储器,如只读存储器(ROM)502、随机访问存储器(RAM)503等,其中,存储器存储有可被至少一个处理器执行的计算机程序,处理器501可以根据存储在只读存储器(ROM)502中的计算机程序或者从存储单元508加载到随机访问存储器(RAM)503中的计算机程序,来执行各种适当的动作和处理。在RAM 503中,还可存储电子设备500操作所需的各种程序和数据。处理器501、ROM 502以及RAM 503通过总线504彼此相连。输入/输出(I/O)接口505也连接至总线504。
电子设备500中的多个部件连接至I/O接口505,包括:输入单元506,例如键盘、鼠标等;输出单元507,例如各种类型的显示器、扬声器等;存储单元508,例如磁盘、光盘等;以及通信单元509,例如网卡、调制解调器、无线通信收发机等。通信单元509允许电子设备500通过诸如因特网的计算机网络和/或各种电信网络与其他设备交换信息/数据。
处理器501可以是各种具有处理和计算能力的通用和/或专用处理组件。处理器501的一些示例包括但不限于中央处理单元(CPU)、图形处理单元(GPU)、各种专用的人工智能(AI)计算芯片、各种运行机器学习模型算法的处理器、数字信号处理器(DSP)、以及任何适当的处理器、控制器、微控制器等。处理器501执行上文所描述的各个方法和处理,例如数据同步方法或图像分类模型的训练方法。
在一些实施例中,数据同步方法或图像分类模型的训练方法可被实现为计算机程序,其被有形地包含于计算机可读存储介质,例如存储单元508。在一些实施例中,计算机程序的部分或者全部可以经由ROM 502和/或通信单元509而被载入和/或安装到电子设备500上。当计算机程序加载到RAM 503并由处理器501执行时,可以执行上文描述的数据同步方法或图像分类模型的训练方法的一个或多个步骤。备选地,在其他实施例中,处理器501可以通过其他任何适当的方式(例如,借助于固件)而被配置为执行数据同步方法或图像分类模型的训练方法。
本文中以上描述的系统和技术的各种实施方式可以在数字电子电路系统、集成电路系统、现场可编程门阵列(FPGA)、专用集成电路(ASIC)、专用标准产品(ASSP)、芯片上系统的系统(SOC)、复杂可编程逻辑设备(CPLD)、计算机硬件、固件、软件、和/或它们的组合中实现。这些各种实施方式可以包括:实施在一个或者多个计算机程序中,该一个或者多个计算机程序可在包括至少一个可编程处理器的可编程系统上执行和/或解释,该可编程处理器可以是专用或者通用可编程处理器,可以从存储系统、至少一个输入装置、和至少一个输出装置接收数据和指令,并且将数据和指令传输至该存储系统、该至少一个输入装置、和该至少一个输出装置。
用于实施本发明的方法的计算机程序可以采用一个或多个编程语言的任何组合来编写。这些计算机程序可以提供给通用计算机、专用计算机或其他可编程数据同步装置的处理器,使得计算机程序当由处理器执行时使流程图和/或框图中所规定的功能/操作被实施。计算机程序可以完全在机器上执行、部分地在机器上执行,作为独立软件包部分地在机器上执行且部分地在远程机器上执行或完全在远程机器或服务器上执行。
在本发明的上下文中,计算机可读存储介质可以是有形的介质,其可以包含或存储以供指令执行系统、装置或设备使用或与指令执行系统、装置或设备结合地使用的计算机程序。计算机可读存储介质可以包括但不限于电子的、磁性的、光学的、电磁的、红外的、或半导体系统、装置或设备,或者上述内容的任何合适组合。备选地,计算机可读存储介质可以是机器可读信号介质。机器可读存储介质的更具体示例会包括基于一个或多个线的电气连接、便携式计算机盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦除可编程只读存储器(EPROM或快闪存储器)、光纤、便捷式紧凑盘只读存储器(CD-ROM)、光学储存设备、磁储存设备、或上述内容的任何合适组合。
为了提供与用户的交互,可以在电子设备上实施此处描述的系统和技术,该电子设备具有:用于向用户显示信息的显示装置(例如,CRT(阴极射线管)或者LCD(液晶显示器)监视器);以及键盘和指向装置(例如,鼠标或者轨迹球),用户可以通过该键盘和该指向装置来将输入提供给电子设备。其它种类的装置还可以用于提供与用户的交互;例如,提供给用户的反馈可以是任何形式的传感反馈(例如,视觉反馈、听觉反馈、或者触觉反馈);并且可以用任何形式(包括声输入、语音输入或者、触觉输入)来接收来自用户的输入。
可以将此处描述的系统和技术实施在包括后台部件的计算系统(例如,作为数据服务器)、或者包括中间件部件的计算系统(例如,应用服务器)、或者包括前端部件的计算系统(例如,具有图形用户界面或者网络浏览器的用户计算机,用户可以通过该图形用户界面或者该网络浏览器来与此处描述的系统和技术的实施方式交互)、或者包括这种后台部件、中间件部件、或者前端部件的任何组合的计算系统中。可以通过任何形式或者介质的数字数据通信(例如,通信网络)来将系统的部件相互连接。通信网络的示例包括:局域网(LAN)、广域网(WAN)、区块链网络和互联网。
计算系统可以包括客户端和服务器。客户端和服务器一般远离彼此并且通常通过通信网络进行交互。通过在相应的计算机上运行并且彼此具有客户端-服务器关系的计算机程序来产生客户端和服务器的关系。服务器可以是云服务器,又称为云计算服务器或云主机,是云计算服务体系中的一项主机产品,以解决了传统物理主机与VPS(VirtualPrivate Server,虚拟专用服务器)服务中,存在的管理难度大,业务扩展性弱的缺陷。
应该理解,可以使用上面所示的各种形式的流程,重新排序、增加或删除步骤。例如,本发明中记载的各步骤可以并行地执行也可以顺序地执行也可以不同的次序执行,只要能够实现本发明的技术方案所期望的结果,本文在此不进行限制。
上述具体实施方式,并不构成对本发明保护范围的限制。本领域技术人员应该明白的是,根据设计要求和其他因素,可以进行各种修正、组合、子组合和替代。任何在本发明的精神和原则之内所作的修正、等同替换和改进等,均应包含在本发明保护范围之内。

Claims (10)

1.一种数据同步方法,其特征在于,所述方法包括:
通过数据同步模块,接收到产品的更新数据,将所述更新数据存储至第一数据库中,并对所述更新数据进行数据转换,得到所述产品的同步数据;
通过数据同步模块,为所述产品的同步数据生成目标同步任务,并向所述同步任务处理器发送所述目标同步任务;
通过同步任务处理模块,接收到所述目标同步任务,根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和所述正在执行同步任务的同步服务器的运行状态参数,确定所述目标同步任务的执行服务器;
通过同步任务处理模块,将所述目标同步任务发送给所述执行服务器,以使所述执行服务器将所述同步数据存储至第二数据库中。
2.根据权利要求1所述的方法,其特征在于,所述根据所述未完成的同步任务的数量、同步服务器的数量和同步服务器的运行状态参数,确定所述目标同步任务的执行服务器,包括:
根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和正在执行同步任务的同步服务器的运行状态参数,对同步服务器集群进行更新,得到更新后的正在执行同步任务的同步服务器集群;所述同步服务器集群包括正在执行同步任务的同步服务器;
从所述更新后的正在执行同步任务的同步服务器集群中确定所述目标同步任务的执行服务器。
3.根据权利要求2所述的方法,其特征在于,所述根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和正在执行同步任务的同步服务器的运行状态参数,对同步服务器集群进行更新,得到更新后的正在执行同步任务的同步服务器集群;所述同步服务器集群包括正在执行同步任务的同步服务器,包括:
根据未完成的同步任务的数量、同步服务器集群包括的同步服务器的数量和所述同步服务器集群包括的同步服务器的运行状态参数确定所述目标同步任务的任务等待时长,并校验所述任务等待时长是否大于预设时长阈值;
若所述任务等待时长小于或等于预设时长阈值,则确定所述同步服务器集群保持不变,并作为更新后的同步服务器集群;
若所述任务等待时长大于所述预设时长阈值,则选择空闲服务器添加到同步服务器集群中,并将添加后的同步服务器集群作为更新后的同步服务器集群;
返回执行根据未完成的同步任务的数量、同步服务器集群包括的同步服务器的数量和所述同步服务器集群包括的同步服务器的运行状态参数确定所述目标同步任务的任务等待时长,并校验所述任务等待时长是否大于预设时长阈值,直至所述任务等待时长小于或等于所述预设时长阈值;
获取当前更新后的同步服务器集群。
4.根据权利要求3所述的方法,其特征在于,所述根据未完成的同步任务的数量、同步服务器集群包括的同步服务器的数量和所述同步服务器集群包括的同步服务器的运行状态参数确定所述目标同步任务的任务等待时长,包括:
根据所述未完成的同步任务的数量和同步服务器集群包括的同步服务器的数量,确定每一同步服务器的未完成的单位任务数量;
将所述单位任务数量和各同步服务器的运行状态参数输入训练好的机器学习模型,得到任务等待时长。
5.根据权利要求4所述的方法,其特征在于,所述根据所述未完成的同步任务的数量和同步服务器集群包括的同步服务器的数量,确定每一同步服务器的未完成的单位任务数量,包括:
更新未完成的同步任务的数量,得到更新后的未完成的同步任务的数量;
根据所述更新后的未完成的同步任务的数量与所述同步服务器集群包括的同步服务器的数量,确定每一同步服务器未完成的单位任务数量。
6.根据权利要求1所述的方法,其特征在于,所述对所述更新数据进行数据转换,得到所述产品的同步数据,包括:
根据预设的数据转换配置信息和所述更新数据,对所述更新数据进行数据转换,得到转换数据;
根据所述产品的标识信息,从所述转换数据去除所述标识信息对应的操作执行过程数据,得到同步数据;所述同步数据包括属性数据。
7.根据权利要求1所述的方法,其特征在于,在通过数据同步模块,接收到产品的更新数据,将所述更新数据存储至第一数据库中,并对所述更新数据进行数据转换,得到所述产品的同步数据之前,还包括:
通过数据获取模块,接收到产品的输入数据,将所述产品数据存储至第三数据库中,并对所述输入数据进行数据转换,得到所述产品的更新数据;
通过所述数据获取模块,将所述产品的更新数据发送给所述数据同步模块。
8.一种数据同步装置,其特征在于,所述装置包括:
数据转换模块,用于通过数据同步模块,接收到产品的更新数据,将所述更新数据存储至第一数据库中,并对所述更新数据进行数据转换,得到所述产品的同步数据;
任务生成模块,用于通过数据同步模块,为所述产品的同步数据生成目标同步任务,并向所述同步任务处理器发送所述目标同步任务;
服务器确定模块,用于通过同步任务处理模块,接收到所述目标同步任务,根据未完成的同步任务的数量、正在执行同步任务的同步服务器的数量和所述正在执行同步任务的同步服务器的运行状态参数,确定所述目标同步任务的执行服务器;
任务发送模块,用于通过同步任务处理模块,将所述目标同步任务发送给所述执行服务器,以使所述执行服务器将所述同步数据存储至第二数据库中。
9.一种电子设备,其特征在于,所述电子设备包括:
至少一个处理器;以及
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的计算机程序,所述计算机程序被所述至少一个处理器执行,以使所述至少一个处理器能够执行权利要求1-7中任一项所述的数据同步方法。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质存储有计算机指令,所述计算机指令用于使处理器执行时实现权利要求1-7中任一项所述的数据同步方法。
CN202311667144.8A 2023-12-06 2023-12-06 一种数据同步方法、装置、设备及介质 Pending CN117668114A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202311667144.8A CN117668114A (zh) 2023-12-06 2023-12-06 一种数据同步方法、装置、设备及介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202311667144.8A CN117668114A (zh) 2023-12-06 2023-12-06 一种数据同步方法、装置、设备及介质

Publications (1)

Publication Number Publication Date
CN117668114A true CN117668114A (zh) 2024-03-08

Family

ID=90067765

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202311667144.8A Pending CN117668114A (zh) 2023-12-06 2023-12-06 一种数据同步方法、装置、设备及介质

Country Status (1)

Country Link
CN (1) CN117668114A (zh)

Similar Documents

Publication Publication Date Title
CN116611411A (zh) 一种业务系统报表生成方法、装置、设备及存储介质
CN116301978A (zh) 一种系统升级方法、装置、设备及存储介质
CN115421728A (zh) 一种业务代码生成方法、装置、电子设备及存储介质
CN117668114A (zh) 一种数据同步方法、装置、设备及介质
CN116915870B (zh) 任务创建请求处理方法、装置、电子设备和可读介质
CN117406964A (zh) 数据架构模型设计方法、装置、电子设备和存储介质
CN117938909A (zh) 一种数据传输方法、装置、设备及介质
CN114117317A (zh) 模型处理方法、装置、设备以及存储介质
CN115510838A (zh) 一种模板生成的方法、装置、电子设备和存储介质
CN117495285A (zh) 申请事件的审批方法、装置、电子设备及存储介质
CN115525614A (zh) 一种数据接入方法、装置、设备、系统及存储介质
CN117193726A (zh) 一种软件的并行设计方法、装置、电子设备以及介质
CN115203876A (zh) 红黑图更新方法、装置、设备及介质
CN115098520A (zh) 设备数据更新方法、装置、电子设备及存储介质
CN115036044A (zh) 一种消息处理方法、装置、电子设备及存储介质
CN117931155A (zh) 一种代码生成方法、装置、设备及介质
CN118051670A (zh) 业务推荐方法、装置、设备和介质
CN117032712A (zh) 流水线编译构建方法、装置、电子设备和存储介质
CN115907779A (zh) 一种交易提案的验证方法、装置、服务器和存储介质
CN115033629A (zh) 一种数据处理方法、装置、电子设备及存储介质
CN117632120A (zh) 一种报表数据的加工系统、方法、设备及存储介质
CN115511085A (zh) 一种模型数据处理方法、装置、设备及存储介质
CN116860751A (zh) 一种数据处理方法、装置、电子设备及存储介质
CN117596141A (zh) 一种报文组装方法、装置、设备及存储介质
CN117651078A (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