CN113434502A - 异构数据库一致性实现方法、系统、电子设备及存储介质 - Google Patents
异构数据库一致性实现方法、系统、电子设备及存储介质 Download PDFInfo
- Publication number
- CN113434502A CN113434502A CN202110713532.XA CN202110713532A CN113434502A CN 113434502 A CN113434502 A CN 113434502A CN 202110713532 A CN202110713532 A CN 202110713532A CN 113434502 A CN113434502 A CN 113434502A
- Authority
- CN
- China
- Prior art keywords
- interface
- calling
- consistency
- heterogeneous
- storage component
- 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
- 238000000034 method Methods 0.000 title claims abstract description 35
- 230000008859 change Effects 0.000 claims abstract description 31
- 238000004590 computer program Methods 0.000 claims description 12
- 238000013461 design Methods 0.000 claims description 11
- 238000011161 development Methods 0.000 abstract description 4
- 238000004891 communication Methods 0.000 description 7
- 238000010586 diagram Methods 0.000 description 7
- 230000006870 function Effects 0.000 description 4
- 238000012545 processing Methods 0.000 description 3
- 230000003287 optical effect Effects 0.000 description 2
- 230000008569 process Effects 0.000 description 2
- 238000005516 engineering process Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
- 230000001360 synchronised effect Effects 0.000 description 1
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/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/22—Indexing; Data structures therefor; Storage structures
- G06F16/2282—Tablespace storage structures; Management thereof
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/23—Updating
- G06F16/2365—Ensuring data consistency and integrity
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/54—Interprogram communication
- G06F9/546—Message passing systems or structures, e.g. queues
-
- 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)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Data Mining & Analysis (AREA)
- Databases & Information Systems (AREA)
- Computer Security & Cryptography (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本发明提出一种异构数据库一致性实现方法、系统、电子设备及存储介质,其方法技术方案包括在一异构数据库的存储子系统设计一第一接口,调用第一接口所实现的操作包括当指定异构数据库中存储组件列表时,根据存储组件列表变更数据;在存储子系统设计一第二接口,调用第二接口所实现的操作包括当不指定存储组件列表时,变更异构处理器中主存储的数据,若变更成功,进一步生成一消息队列,消息队列包括还需变更的其他存储组件列表;根据一预设调用顺序调用第一接口和第二接口,通过对第一接口和第二接口的调用实现异构数据库中的最终一致性。本申请解决了现有异构数据库一致性实现方法开发成本较高的问题。
Description
技术领域
本发明属于数据库技术领域,尤其涉及一种异构数据库一致性实现方法、系统、电子设备及存储介质。
背景技术
所谓的异构数据库,指的是数据库包含多种存储组件,每种存储组件用于支撑不同的功能。这样的话,就可以实现单种存储组件所无法实现的功能。举例而言,在异构图数据库NEST中,就包含了四种存储组件,分别是用于图存储的组件,用于倒排索引存储的组件,用于OLAP存储的组件,以及用于历史版本存储的组件,通过组合这四种存储组件,NEST可以实现图谱推理,搜索,OLAP查询,历史版本变更记录及查询等功能,而这是单一的存储组件所难以实现的。
不过,组合多种存储组件也带来了一些问题,其中最主要的问题就是,如何保证多种存储组件中的数据是一致的。特别是,在写入或者删除某一种或几种存储组件失败的时候,如何保证多种存储组件中的数据是一致的。在现有技术中,一般是通过某种方式实现强一致性的,也有选择不实现一致性的。实现强一致性的问题在于开发成本比较高,不实现一致性的问题则在于在有些场景下,数据的不一致会极大的影响用户的体验。
发明内容
本申请实施例提供了一种异构数据库一致性实现方法、系统、电子设备及存储介质,以至少解决现有异构数据库一致性实现方法开发成本较高的问题。
第一方面,本申请实施例提供了一种异构数据库一致性实现方法,包括:第一接口设计步骤,在一异构数据库的存储子系统设计一第一接口,调用所述第一接口所实现的操作包括当指定所述异构数据库中存储组件列表时,根据所述存储组件列表变更数据;第二接口设计步骤,在所述存储子系统设计一第二接口,调用所述第二接口所实现的操作包括当不指定所述存储组件列表时,变更所述异构处理器中主存储的数据,若变更成功,进一步生成一消息队列,所述消息队列包括还需变更的其他所述存储组件列表;接口调用执行步骤,根据一预设调用顺序调用所述第一接口和所述第二接口,通过对所述第一接口和所述第二接口的调用实现所述异构数据库中的最终一致性。
优选的,所述接口调用执行步骤进一步包括:第二接口调用步骤,调用第二接口,并在所述第二接口的返回值中说明变更的结果。
优选的,所述接口调用执行步骤进一步包括:消息队列读取步骤,若调用所述第二接口进行的变更成功,则通过所述异构数据库中的一致性子系统从所述消息队列中读取消息。
优选的,所述接口调用执行步骤进一步包括:第一接口调用步骤,根据所述消息调用所述第一接口,包括根据所述消息中的还需变更的其他所述存储组件列表进行变更,若变更失败,则将失败的所述存储组件列表再次写入所述消息队列。
第二方面,本申请实施例提供了一种异构数据库一致性实现系统,适用于上述一种异构数据库一致性实现方法,包括:第一接口设计模块,在一异构数据库的存储子系统设计一第一接口,调用所述第一接口所实现的操作包括当指定所述异构数据库中存储组件列表时,根据所述存储组件列表变更数据;第二接口设计模块,在所述存储子系统设计一第二接口,调用所述第二接口所实现的操作包括当不指定所述存储组件列表时,变更所述异构处理器中主存储的数据,若变更成功,进一步生成一消息队列,所述消息队列包括还需变更的其他所述存储组件列表;接口调用执行模块,根据一预设调用顺序调用所述第一接口和所述第二接口,通过对所述第一接口和所述第二接口的调用实现所述异构数据库中的最终一致性。
在其中一些实施例中,所述接口调用执行模块进一步包括:第二接口调用单元,调用第二接口,并在所述第二接口的返回值中说明变更的结果。
在其中一些实施例中,所述接口调用执行模块进一步包括:消息队列读取单元,若调用所述第二接口进行的变更成功,则通过所述异构数据库中的一致性子系统从所述消息队列中读取消息。
在其中一些实施例中,所述接口调用执行模块进一步包括:第一接口调用单元,根据所述消息调用所述第一接口,包括根据所述消息中的还需变更的其他所述存储组件列表进行变更,若变更失败,则将失败的所述存储组件列表再次写入所述消息队列。
第三方面,本申请实施例提供了一种电子设备,包括存储器、处理器以及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如上述第一方面所述的一种异构数据库一致性实现方法。
第四方面,本申请实施例提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现如上述第一方面所述的一种异构数据库一致性实现方法。
本申请可应用于数据能力技术领域。相比于相关技术,本申请实施例提供的一种异构数据库一致性实现方法,通过消息队列暂存需要达成最终一致性的数据及存储组件,以及提供两个不同的API接口分别用于外部用户变更数据及内部一致性子系统达成存储组件之间的一致性实现的成本较低,且可以在一定程度上满足用户对于数据一致性的要求。
附图说明
此处所说明的附图用来提供对本申请的进一步理解,构成本申请的一部分,本申请的示意性实施例及其说明用于解释本申请,并不构成对本申请的不当限定。在附图中:
图1为本发明的异构数据库一致性实现方法流程图;
图2为图1中步骤S3的分步骤流程图;
图3为本发明的异构数据库一致性实现系统的框架图;
图4为本发明的电子设备的框架图;
以上图中:
1、第一接口设计模块;2、第二接口设计模块;3、接口调用执行模块;31、第二接口调用单元;32、消息队列读取单元;33、第一接口调用单元;60、总线;61、处理器;62、存储器;63、通信接口。
具体实施方式
为了使本申请的目的、技术方案及优点更加清楚明白,以下结合附图及实施例,对本申请进行描述和说明。应当理解,此处所描述的具体实施例仅仅用以解释本申请,并不用于限定本申请。基于本申请提供的实施例,本领域普通技术人员在没有作出创造性劳动的前提下所获得的所有其他实施例,都属于本申请保护的范围。
显而易见地,下面描述中的附图仅仅是本申请的一些示例或实施例,对于本领域的普通技术人员而言,在不付出创造性劳动的前提下,还可以根据这些附图将本申请应用于其他类似情景。此外,还可以理解的是,虽然这种开发过程中所作出的努力可能是复杂并且冗长的,然而对于与本申请公开的内容相关的本领域的普通技术人员而言,在本申请揭露的技术内容的基础上进行的一些设计,制造或者生产等变更只是常规的技术手段,不应当理解为本申请公开的内容不充分。
在本申请中提及“实施例”意味着,结合实施例描述的特定特征、结构或特性可以包含在本申请的至少一个实施例中。在说明书中的各个位置出现该短语并不一定均是指相同的实施例,也不是与其它实施例互斥的独立的或备选的实施例。本领域普通技术人员显式地和隐式地理解的是,本申请所描述的实施例在不冲突的情况下,可以与其它实施例相结合。
除非另作定义,本申请所涉及的技术术语或者科学术语应当为本申请所属技术领域内具有一般技能的人士所理解的通常意义。本申请所涉及的“一”、“一个”、“一种”、“该”等类似词语并不表示数量限制,可表示单数或复数。本申请所涉及的术语“包括”、“包含”、“具有”以及它们任何变形,意图在于覆盖不排他的包含;例如包含了一系列步骤或模块(单元)的过程、方法、系统、产品或设备没有限定于已列出的步骤或单元,而是可以还包括没有列出的步骤或单元,或可以还包括对于这些过程、方法、产品或设备固有的其它步骤或单元。
针对强一致性和不实现一致性这两种方案各自的问题,本申请实施例选择实现了最终一致性,所谓的最终一致性,指的是多种存储组件最终会达成一致,理论上来说,最终一致性只能保证在未来的某一个时间点上多种存储组件会达成一致,这个时间点距离写入或者删除的时间点究竟有多遥远,是无法保证的,实际上,在大多数情况下,一般在秒级或者分钟级,就可以达成一致性了。与实现强一致性相比,实现最终一致性的成本要低得多,而且,在大多数情况下,不会因为数据的不一致影响用户的体验。
本申请实施例以异构图数据库NEST为例来说明,如前所述,NEST中包含四种存储组件:图存储、倒排索引存储、OLAP存储和历史版本存储,在这四种存储组件中,将图存储称之为主存储,在数据被写入图存储之后,就已经在部分程度上可用了,可以提供给用户使用,在其他存储也被写入之后,数据就完全可用了。此外,NEST由两个子系统组成,分别为存储子系统及一致性子系统。如其名称所示,存储子系统主要负责存储,一致性子系统主要负责实现最终一致性。需要说明的是,NEST所存储的数据都是有唯一主键的。
以下,结合附图详细介绍本发明的实施例:
图1为本发明的异构数据库一致性实现方法流程图,请参见图1,本发明异构数据库一致性实现方法包括如下步骤:
S1:在一异构数据库的存储子系统设计一第一接口,调用所述第一接口所实现的操作包括当指定所述异构数据库中存储组件列表时,根据所述存储组件列表变更数据。
在具体实施中,本申请实施例的存储子系统提供了两个API接口供一致性子系统或者外部用户调用。第一接口即为:指定存储组件列表,写入或者删除(本申请统称为变更)数据。在这种情况下,存储子系统将会变更指定的存储组件。无论变更成功还是失败,都会在API接口的返回值中说明,如果是部分存储组件失败,也会在API接口的返回值中说明是哪些存储组件失败。
S2:在所述存储子系统设计一第二接口,调用所述第二接口所实现的操作包括当不指定所述存储组件列表时,变更所述异构处理器中主存储的数据,若变更成功,进一步生成一消息队列,所述消息队列包括还需变更的其他所述存储组件列表。
在具体实施中,第二接口即为:不指定存储组件,变更数据。在这种情况下,存储子系统将会变更图存储。如果变更图存储成功的话,存储子系统会进而将一条消息写入消息队列。消息中包含数据本身、对数据的操作是写入还是删除以及还需要写入的存储组件列表,在这种情况下还需要写入的存储组件列表为除了图存储之外的其他三种存储。如果变更图存储失败的话,则存储子系统不会将数据写入消息队列。无论变更成功还是失败,都会在API接口的返回值中说明。
S3:根据一预设调用顺序调用所述第一接口和所述第二接口,通过对所述第一接口和所述第二接口的调用实现所述异构数据库中的最终一致性。
可选的,图2为图1中步骤S3的分步骤流程图,请参见图2,图2为本申请实施例中一种主要的调用顺序:
S31:调用第二接口,并在所述第二接口的返回值中说明变更的结果。
在具体实施中,调用方调用第二接口,如果调用方调用第二接口的结果是成功,说明已经在图存储中变更了数据,且把数据放入了消息队列,在这种情况下,如果是写入数据的话,数据已经在某种程度上可用了,如果是删除数据的话,数据在某种程度上也可以被视为已经删除了。如果调用方调用第二接口的结果是失败,说明未能在图存储中变更数据,在这种情况下,由调用方决定是否重试以及如何重试。
S32:若调用所述第二接口进行的变更成功,则通过所述异构数据库中的一致性子系统从所述消息队列中读取消息。
S33:根据所述消息调用所述第一接口,包括根据所述消息中的还需变更的其他所述存储组件列表进行变更,若变更失败,则将失败的所述存储组件列表再次写入所述消息队列。
在具体实施中,一致性子系统从消息队列中读取消息,并调用第一接口,如前所述,消息本身中包含数据本身、对数据的操作是写入还是删除以及还需要写入的存储组件列表。
在具体实施中,如果一致性子系统调用第一接口成功,说明所有的存储组件都已经变更成功,在这条数据上已经达成了一致性。如果调用失败,说明有部分存储组件变更失败了,在这种情况下,只需要将数据本身、对数据的操作是写入还是删除以及失败了的存储组件列表再次写入消息队列即可,这样,当一致性子系统再次读取到这条消息的时候,就会再次尝试变更之前变更失败了的数据。如此循环往复,直到最终达成一致性。
需要说明的是,在上述流程中或者附图的流程图中示出的步骤可以在诸如一组计算机可执行指令的计算机系统中执行,并且,虽然在流程图中示出了逻辑顺序,但是在某些情况下,可以以不同于此处的顺序执行所示出或描述的步骤。
本申请实施例提供了一种异构数据库一致性实现系统,适用于上述的一种异构数据库一致性实现方法。如以下所使用的,术语“单元”、“模块”等可以实现预定功能的软件和/或硬件的组合。尽管以下实施例所描述的装置较佳地以软件来实现,但是硬件、或者软件和硬件的组合的实现也是可能并被构想的。
图3为根据本发明的异构数据库一致性实现系统的框架图,请参见图3,包括:
第一接口设计模块1:在一异构数据库的存储子系统设计一第一接口,调用所述第一接口所实现的操作包括当指定所述异构数据库中存储组件列表时,根据所述存储组件列表变更数据。
在具体实施中,本申请实施例的存储子系统提供了两个API接口供一致性子系统或者外部用户调用。第一接口即为:指定存储组件列表,写入或者删除(本申请统称为变更)数据。在这种情况下,存储子系统将会变更指定的存储组件。无论变更成功还是失败,都会在API接口的返回值中说明,如果是部分存储组件失败,也会在API接口的返回值中说明是哪些存储组件失败。
第二接口设计模块2:在所述存储子系统设计一第二接口,调用所述第二接口所实现的操作包括当不指定所述存储组件列表时,变更所述异构处理器中主存储的数据,若变更成功,进一步生成一消息队列,所述消息队列包括还需变更的其他所述存储组件列表。
在具体实施中,第二接口即为:不指定存储组件,变更数据。在这种情况下,存储子系统将会变更图存储。如果变更图存储成功的话,存储子系统会进而将一条消息写入消息队列。消息中包含数据本身、对数据的操作是写入还是删除以及还需要写入的存储组件列表,在这种情况下还需要写入的存储组件列表为除了图存储之外的其他三种存储。如果变更图存储失败的话,则存储子系统不会将数据写入消息队列。无论变更成功还是失败,都会在API接口的返回值中说明。
接口调用执行模块3:根据一预设调用顺序调用所述第一接口和所述第二接口,通过对所述第一接口和所述第二接口的调用实现所述异构数据库中的最终一致性。
可选的,本申请实施例中提供一种主要的调用顺序,接口调用执行模块3包括:
第二接口调用单元31:调用第二接口,并在所述第二接口的返回值中说明变更的结果。
在具体实施中,调用方调用第二接口,如果调用方调用第二接口的结果是成功,说明已经在图存储中变更了数据,且把数据放入了消息队列,在这种情况下,如果是写入数据的话,数据已经在某种程度上可用了,如果是删除数据的话,数据在某种程度上也可以被视为已经删除了。如果调用方调用第二接口的结果是失败,说明未能在图存储中变更数据,在这种情况下,由调用方决定是否重试以及如何重试。
消息队列读取单元32:若调用所述第二接口进行的变更成功,则通过所述异构数据库中的一致性子系统从所述消息队列中读取消息。
第一接口调用单元33:根据所述消息调用所述第一接口,包括根据所述消息中的还需变更的其他所述存储组件列表进行变更,若变更失败,则将失败的所述存储组件列表再次写入所述消息队列。
在具体实施中,一致性子系统从消息队列中读取消息,并调用第一接口,如前所述,消息本身中包含数据本身、对数据的操作是写入还是删除以及还需要写入的存储组件列表。
在具体实施中,如果一致性子系统调用第一接口成功,说明所有的存储组件都已经变更成功,在这条数据上已经达成了一致性。如果调用失败,说明有部分存储组件变更失败了,在这种情况下,只需要将数据本身、对数据的操作是写入还是删除以及失败了的存储组件列表再次写入消息队列即可,这样,当一致性子系统再次读取到这条消息的时候,就会再次尝试变更之前变更失败了的数据。如此循环往复,直到最终达成一致性。
另外,结合图1、图2描述的一种异构数据库一致性实现方法可以由电子设备来实现。图4为本发明的电子设备的框架图。
电子设备可以包括处理器61以及存储有计算机程序指令的存储器62。
具体地,上述处理器61可以包括中央处理器(CPU),或者特定集成电路(Application Specific Integrated Circuit,简称为ASIC),或者可以被配置成实施本申请实施例的一个或多个集成电路。
其中,存储器62可以包括用于数据或指令的大容量存储器。举例来说而非限制,存储器62可包括硬盘驱动器(Hard Disk Drive,简称为HDD)、软盘驱动器、固态驱动器(SolidState Drive,简称为SSD)、闪存、光盘、磁光盘、磁带或通用串行总线(Universal SerialBus,简称为USB)驱动器或者两个或更多个以上这些的组合。在合适的情况下,存储器62可包括可移除或不可移除(或固定)的介质。在合适的情况下,存储器62可在数据处理装置的内部或外部。在特定实施例中,存储器62是非易失性(Non-Volatile)存储器。在特定实施例中,存储器62包括只读存储器(Read-Only Memory,简称为ROM)和随机存取存储器(RandomAccess Memory,简称为RAM)。在合适的情况下,该ROM可以是掩模编程的ROM、可编程ROM(Programmable Read-Only Memory,简称为PROM)、可擦除PROM(Erasable ProgrammableRead-Only Memory,简称为EPROM)、电可擦除PROM(Electrically Erasable ProgrammableRead-Only Memory,简称为EEPROM)、电可改写ROM(Electrically Alterable Read-OnlyMemory,简称为EAROM)或闪存(FLASH)或者两个或更多个以上这些的组合。在合适的情况下,该RAM可以是静态随机存取存储器(Static Random-Access Memory,简称为SRAM)或动态随机存取存储器(Dynamic Random Access Memory,简称为DRAM),其中,DRAM可以是快速页模式动态随机存取存储器(Fast Page Mode Dynamic Random Access Memory,简称为FPMDRAM)、扩展数据输出动态随机存取存储器(Extended Date Out Dynamic RandomAccess Memory,简称为EDODRAM)、同步动态随机存取内存(Synchronous Dynamic Random-Access Memory,简称SDRAM)等。
存储器62可以用来存储或者缓存需要处理和/或通信使用的各种数据文件,以及处理器61所执行的可能的计算机程序指令。
处理器61通过读取并执行存储器62中存储的计算机程序指令,以实现上述实施例中的任意一种异构数据库一致性实现方法。
在其中一些实施例中,电子设备还可包括通信接口63和总线60。其中,如图4所示,处理器61、存储器62、通信接口63通过总线60连接并完成相互间的通信。
通信端口63可以实现与其他部件例如:外接设备、图像/数据采集设备、数据库、外部存储以及图像/数据处理工作站等之间进行数据通信。
总线60包括硬件、软件或两者,将电子设备的部件彼此耦接在一起。总线60包括但不限于以下至少之一:数据总线(Data Bus)、地址总线(Address Bus)、控制总线(ControlBus)、扩展总线(Expansion Bus)、局部总线(Local Bus)。举例来说而非限制,总线60可包括图形加速接口(Accelerated Graphics Port,简称为AGP)或其他图形总线、增强工业标准架构(Extended Industry Standard Architecture,简称为EISA)总线、前端总线(FrontSide Bus,简称为FSB)、超传输(Hyper Transport,简称为HT)互连、工业标准架构(Industry Standard Architecture,简称为ISA)总线、无线带宽(InfiniBand)互连、低引脚数(Low Pin Count,简称为LPC)总线、存储器总线、微信道架构(Micro ChannelArchitecture,简称为MCA)总线、外围组件互连(Peripheral Component Interconnect,简称为PCI)总线、PCI-Express(PCI-X)总线、串行高级技术附件(Serial AdvancedTechnology Attachment,简称为SATA)总线、视频电子标准协会局部(Video ElectronicsStandards Association Local Bus,简称为VLB)总线或其他合适的总线或者两个或更多个以上这些的组合。在合适的情况下,总线60可包括一个或多个总线。尽管本申请实施例描述和示出了特定的总线,但本申请考虑任何合适的总线或互连。
该电子设备可以执行本申请实施例中的一种异构数据库一致性实现方法。
另外,结合上述实施例中的一种异构数据库一致性实现方法,本申请实施例可提供一种计算机可读存储介质来实现。该计算机可读存储介质上存储有计算机程序指令;该计算机程序指令被处理器执行时实现上述实施例中的任意一种异构数据库一致性实现方法。
而前述的存储介质包括:U盘、移动硬盘、只读存储器(ReadOnly Memory,简称为ROM)、随机存取存储器(Random Access Memory,简称为RAM)、磁碟或者光盘等各种可以存储程序代码的介质。
以上所述实施例的各技术特征可以进行任意的组合,为使描述简洁,未对上述实施例中的各个技术特征所有可能的组合都进行描述,然而,只要这些技术特征的组合不存在矛盾,都应当认为是本说明书记载的范围。
以上所述实施例仅表达了本申请的几种实施方式,其描述较为具体和详细,但并不能因此而理解为对发明专利范围的限制。应当指出的是,对于本领域的普通技术人员来说,在不脱离本申请构思的前提下,还可以做出若干变形和改进,这些都属于本申请的保护范围。因此,本申请专利的保护范围应以所附权利要求为准。
Claims (10)
1.一种异构数据库一致性实现方法,其特征在于,包括:
第一接口设计步骤,在一异构数据库的存储子系统设计一第一接口,调用所述第一接口所实现的操作包括当指定所述异构数据库中存储组件列表时,根据所述存储组件列表变更数据;
第二接口设计步骤,在所述存储子系统设计一第二接口,调用所述第二接口所实现的操作包括当不指定所述存储组件列表时,变更所述异构处理器中主存储的数据,若变更成功,进一步生成一消息队列,所述消息队列包括还需变更的其他所述存储组件列表;
接口调用执行步骤,根据一预设调用顺序调用所述第一接口和所述第二接口,通过对所述第一接口和所述第二接口的调用实现所述异构数据库中的最终一致性。
2.根据权利要求1所述的异构数据库一致性实现方法,其特征在于,所述接口调用执行步骤进一步包括:
第二接口调用步骤,调用第二接口,并在所述第二接口的返回值中说明变更的结果。
3.根据权利要求2所述的异构数据库一致性实现方法,其特征在于,所述接口调用执行步骤进一步包括:
消息队列读取步骤,若调用所述第二接口进行的变更成功,则通过所述异构数据库中的一致性子系统从所述消息队列中读取消息。
4.根据权利要求3所述的异构数据库一致性实现方法,其特征在于,所述接口调用执行步骤进一步包括:
第一接口调用步骤,根据所述消息调用所述第一接口,包括根据所述消息中的还需变更的其他所述存储组件列表进行变更,若变更失败,则将失败的所述存储组件列表再次写入所述消息队列。
5.一种异构数据库一致性实现系统,其特征在于,包括:
第一接口设计模块,在一异构数据库的存储子系统设计一第一接口,调用所述第一接口所实现的操作包括当指定所述异构数据库中存储组件列表时,根据所述存储组件列表变更数据;
第二接口设计模块,在所述存储子系统设计一第二接口,调用所述第二接口所实现的操作包括当不指定所述存储组件列表时,变更所述异构处理器中主存储的数据,若变更成功,进一步生成一消息队列,所述消息队列包括还需变更的其他所述存储组件列表;
接口调用执行模块,根据一预设调用顺序调用所述第一接口和所述第二接口,通过对所述第一接口和所述第二接口的调用实现所述异构数据库中的最终一致性。
6.根据权利要求5所述的异构数据库一致性实现系统,其特征在于,所述接口调用执行模块进一步包括:
第二接口调用单元,调用第二接口,并在所述第二接口的返回值中说明变更的结果。
7.根据权利要求6所述的异构数据库一致性实现系统,其特征在于,所述接口调用执行模块进一步包括:
消息队列读取单元,若调用所述第二接口进行的变更成功,则通过所述异构数据库中的一致性子系统从所述消息队列中读取消息。
8.根据权利要求7所述的异构数据库一致性实现系统,其特征在于,所述接口调用执行模块进一步包括:
第一接口调用单元,根据所述消息调用所述第一接口,包括根据所述消息中的还需变更的其他所述存储组件列表进行变更,若变更失败,则将失败的所述存储组件列表再次写入所述消息队列。
9.一种电子设备,包括存储器、处理器以及存储在所述存储器上并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求1至4中任一项所述的异构数据库一致性实现方法。
10.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1至4中任一项所述的异构数据库一致性实现方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110713532.XA CN113434502B (zh) | 2021-06-25 | 2021-06-25 | 异构数据库一致性实现方法、系统、电子设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110713532.XA CN113434502B (zh) | 2021-06-25 | 2021-06-25 | 异构数据库一致性实现方法、系统、电子设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN113434502A true CN113434502A (zh) | 2021-09-24 |
CN113434502B CN113434502B (zh) | 2024-03-01 |
Family
ID=77754628
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110713532.XA Active CN113434502B (zh) | 2021-06-25 | 2021-06-25 | 异构数据库一致性实现方法、系统、电子设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN113434502B (zh) |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101867501A (zh) * | 2010-05-25 | 2010-10-20 | 北京宜富泰网络测试实验室有限公司 | Snmp接口信息模型一致性自动化测试方法及系统 |
KR101747270B1 (ko) * | 2016-08-09 | 2017-06-14 | 주식회사 티맥스데이터 | 이기종 데이터베이스들 간의 쿼리 결과를 동기화하기 위한 방법, 서버 및 컴퓨터-판독가능 매체에 저장된 컴퓨터 프로그램 |
CN110674213A (zh) * | 2019-08-30 | 2020-01-10 | 中国人民财产保险股份有限公司 | 一种数据同步方法及装置 |
CN110765144A (zh) * | 2019-10-11 | 2020-02-07 | 口碑(上海)信息技术有限公司 | 分布式异构数据库数据处理方法及装置 |
CN112905613A (zh) * | 2021-02-08 | 2021-06-04 | 中国工商银行股份有限公司 | 一种异构数据库的数据双向同步方法及装置 |
CN112948409A (zh) * | 2021-03-31 | 2021-06-11 | 中国建设银行股份有限公司 | 一种数据处理方法、装置、电子设备及存储介质 |
-
2021
- 2021-06-25 CN CN202110713532.XA patent/CN113434502B/zh active Active
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101867501A (zh) * | 2010-05-25 | 2010-10-20 | 北京宜富泰网络测试实验室有限公司 | Snmp接口信息模型一致性自动化测试方法及系统 |
KR101747270B1 (ko) * | 2016-08-09 | 2017-06-14 | 주식회사 티맥스데이터 | 이기종 데이터베이스들 간의 쿼리 결과를 동기화하기 위한 방법, 서버 및 컴퓨터-판독가능 매체에 저장된 컴퓨터 프로그램 |
CN110674213A (zh) * | 2019-08-30 | 2020-01-10 | 中国人民财产保险股份有限公司 | 一种数据同步方法及装置 |
CN110765144A (zh) * | 2019-10-11 | 2020-02-07 | 口碑(上海)信息技术有限公司 | 分布式异构数据库数据处理方法及装置 |
CN112905613A (zh) * | 2021-02-08 | 2021-06-04 | 中国工商银行股份有限公司 | 一种异构数据库的数据双向同步方法及装置 |
CN112948409A (zh) * | 2021-03-31 | 2021-06-11 | 中国建设银行股份有限公司 | 一种数据处理方法、装置、电子设备及存储介质 |
Non-Patent Citations (1)
Title |
---|
褚福影: "集成消息队列的数据库中间件研究与实现", 中国优秀硕士学位论文全文数据库信息科技辑 * |
Also Published As
Publication number | Publication date |
---|---|
CN113434502B (zh) | 2024-03-01 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN107391628B (zh) | 数据同步方法及装置 | |
CN108319654B (zh) | 计算系统、冷热数据分离方法及装置、计算机可读存储介质 | |
CN107038206B (zh) | Lsm树的建立方法、lsm树的数据读取方法和服务器 | |
CN111383031B (zh) | 一种区块链中的智能合约执行方法、系统和电子设备 | |
CN111444192B (zh) | 块链式账本中全局状态的哈希的生成方法、装置及设备 | |
CN112181902B (zh) | 数据库的存储方法、装置及电子设备 | |
CN111241040B (zh) | 信息获取方法、装置、电子设备及计算机存储介质 | |
CN115408411A (zh) | 数据写入方法、装置、电子设备及存储介质 | |
CN115328924A (zh) | 一种创建表空间的方法、装置、存储介质及电子设备 | |
CN114117992A (zh) | 一种序列化和反序列化方法、装置和电子设备 | |
CN113486109A (zh) | 异构数据库的数据同步方法、装置及电子设备 | |
CN111857600B (zh) | 一种数据读写方法及装置 | |
US10776334B2 (en) | Random walking and cluster-based random walking method, apparatus and device | |
CN113434502B (zh) | 异构数据库一致性实现方法、系统、电子设备及存储介质 | |
CN111625500B (zh) | 文件快照方法及装置、电子设备和存储介质 | |
CN115033350A (zh) | 一种分布式事务的执行方法及装置 | |
CN113536047A (zh) | 一种图数据库数据删除方法、系统、电子设备及存储介质 | |
CN110825652B (zh) | 淘汰磁盘块上的缓存数据的方法、装置及设备 | |
CN107436918B (zh) | 数据库实现方法、装置和设备 | |
CN107305582B (zh) | 一种元数据处理方法及装置 | |
CN113672601A (zh) | 一种流式数据补齐方法、系统、电子设备及存储介质 | |
CN112162950B (zh) | 基于文件系统的数据处理方法、装置和计算机设备 | |
CN112580297B (zh) | 一种编解码数据的方法、电子设备及存储介质 | |
CN113254452A (zh) | 设备id的存储方法、系统、存储介质及电子设备 | |
CN115809140A (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 | ||
TA01 | Transfer of patent application right | ||
TA01 | Transfer of patent application right |
Effective date of registration: 20230921 Address after: Room 401, 4th Floor, Building J, Yunmi City, No. 19 Ningshuang Road, Yuhuatai District, Nanjing City, Jiangsu Province, 210000 Applicant after: Nanjing Minglue Technology Co.,Ltd. Address before: 100089 a1002, 10th floor, building 1, yard 1, Zhongguancun East Road, Haidian District, Beijing Applicant before: MININGLAMP SOFTWARE SYSTEMS Co.,Ltd. |
|
GR01 | Patent grant | ||
GR01 | Patent grant |