CN112749233B - 数据同步方法、装置、电子设备及存储介质 - Google Patents

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

Info

Publication number
CN112749233B
CN112749233B CN202110057596.9A CN202110057596A CN112749233B CN 112749233 B CN112749233 B CN 112749233B CN 202110057596 A CN202110057596 A CN 202110057596A CN 112749233 B CN112749233 B CN 112749233B
Authority
CN
China
Prior art keywords
service data
data
data source
service
cache
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.)
Active
Application number
CN202110057596.9A
Other languages
English (en)
Other versions
CN112749233A (zh
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.)
Jingdong Technology Holding Co Ltd
Original Assignee
Jingdong Technology Holding 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 Jingdong Technology Holding Co Ltd filed Critical Jingdong Technology Holding Co Ltd
Priority to CN202110057596.9A priority Critical patent/CN112749233B/zh
Publication of CN112749233A publication Critical patent/CN112749233A/zh
Application granted granted Critical
Publication of CN112749233B publication Critical patent/CN112749233B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/27Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/23Updating
    • G06F16/2365Ensuring data consistency and integrity
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/24Querying
    • G06F16/245Query processing
    • G06F16/2455Query execution
    • G06F16/24552Database cache management
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/28Databases characterised by their database models, e.g. relational or object models
    • G06F16/284Relational databases

Landscapes

  • Engineering & Computer Science (AREA)
  • Databases & Information Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Data Mining & Analysis (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Computational Linguistics (AREA)
  • Computer Security & Cryptography (AREA)
  • Computing Systems (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Hardware Redundancy (AREA)

Abstract

本发明实施例提供了一种数据同步方法、装置、电子设备及存储介质,所述方法包括:获取第一业务数据,确定存储所述第一业务数据的数据源,并清空所述数据源对应的缓存组件中的第二业务数据;若成功清空所述数据源对应的缓存组件中的所述第二业务数据,将所述第一业务数据存储至所述数据源;若成功将所述第一业务数据存储至所述数据源,将所述第一业务数据同步至所述缓存组件;若成功将所述第一业务数据同步至所述缓存组件,更新所述第一业务数据的同步状态。本发明实施例在将第一业务数据真正存储至数据源之前,清空数据源对应的缓存组件中的第二业务数据,如此缓存组件中业务数据为空,可以避免对业务产生影响,确定业务正常安全运转。

Description

数据同步方法、装置、电子设备及存储介质
技术领域
本发明涉及数据处理技术领域,尤其涉及一种数据同步方法、装置、电子设备及存储介质。
背景技术
随着互联网的逐渐发展,Redis(Remote Dictionary Server,远程字典服务)已经逐渐成为一个必不可少的辅助工具,在应对高并发、高复杂场景中Redis的身影随处可见。Redis提供了key-value、对象、列表等存储方式,可以满足绝大多数业务的要求。通常来说Redis中数据来源于业务中数据,而业务中数据通常存储到数据库中。Redis作为辅助工具,决定了业务能够支持的并发性和响应时间,Redis中数据如何同数据库中数据保持一致是急需解决的问题。
相关技术中,可以先将业务中数据存储至数据库,然后将数据库中数据同步至Redis,进而由Redis提供业务数据查询的功能。如果业务中数据成功存储至数据库,但是数据库中数据同步至Redis失败,那么Redis中数据未与数据库中数据保持一致,Redis中数据是历史数据(非最新数据),由于Redis提供业务数据查询的功能,Redis中数据将对业务产生影响,有可能导致业务出现告警、崩溃等现象。
发明内容
本发明实施例的目的在于提供一种数据同步方法、装置、电子设备及存储介质,以实现避免对业务产生影响,确定业务正常安全运转的有益效果。具体技术方案如下:
在本发明实施例的第一方面,首先提供了一种数据同步方法,所述方法包括:
获取第一业务数据,确定存储所述第一业务数据的数据源,并清空所述数据源对应的缓存组件中的第二业务数据;
若成功清空所述数据源对应的缓存组件中的所述第二业务数据,将所述第一业务数据存储至所述数据源;
若成功将所述第一业务数据存储至所述数据源,将所述第一业务数据同步至所述缓存组件;
若成功将所述第一业务数据同步至所述缓存组件,更新所述第一业务数据的同步状态。
在一个可选的实施方式中,所述数据源包括第一数据源和第二数据源;
所述若成功清空所述数据源对应的缓存组件中的所述第二业务数据,将所述第一业务数据存储至所述数据源,包括:
若成功清空所述数据源对应的缓存组件中的所述第二业务数据,将所述第一业务数据存储至所述第一数据源;以及,
在所述第一数据源中提取所述第一业务数据对应的主键ID,将所述主键ID存储至所述第二数据源。
在一个可选的实施方式中,所述若成功将所述第一业务数据同步至所述缓存组件,更新所述第一业务数据的同步状态,包括:
若成功将所述第一业务数据同步至所述缓存组件,在所述第二数据源中更新所述第一业务数据对应的所述主键ID的同步状态。
在一个可选的实施方式中,所述方法还包括:
若未成功清空所述数据源对应的缓存组件中的所述第二业务数据,或者,若未成功将所述第一业务数据存储至所述数据源,按照预设的扫描周期扫描所述第一数据源中的第三业务数据;
判断所述第三业务数据是否与所述缓存组件中的所述第二业务数据一致;
若所述第三业务数据与所述缓存组件中的所述第二业务数据未一致,从所述第三业务数据中查找未存在于所述缓存组件的缺失业务数据;
将所述缺失业务数据同步至所述缓存组件。
在一个可选的实施方式中,所述方法还包括:
若未成功将所述第一业务数据同步至所述缓存组件,按照预设的同步周期获取所述第二数据源中的所述主键ID;
根据所述主键ID在所述第一数据源查找所述主键ID对应的所述第一业务数据,将所述第一业务数据同步至所述缓存组件;
若成功将所述第一业务数据同步至所述缓存组件,在所述第二数据源中更新所述第一业务数据对应的所述主键ID的同步状态。
在一个可选的实施方式中,所述根据所述主键ID在所述第一数据源查找所述主键ID对应的所述第一业务数据,将所述第一业务数据同步至所述缓存组件,包括:
根据所述主键ID在所述第一数据源查找所述主键ID对应的所述第一业务数据,判断所述主键ID的同步状态是否为未同步;
若所述主键ID的同步状态为未同步,将所述第一业务数据同步至所述缓存组件。
在一个可选的实施方式中,所述方法还包括:
当接收到业务数据查询请求中,解析所述业务数据查询请求中携带的数据标识;
判断所述缓存组件中是否存在所述数据标识对应的目标业务数据;
若所述缓存组件中存在所述数据标识对应的目标业务数据,将所述目标业务数据返回至所述业务数据查询请求的发出者;
若所述缓存组件中未存在所述数据标识对应的目标业务数据,向所述业务数据查询请求的发出者返回业务数据查询失败的消息。
在本发明实施例的第二方面,还提供了一种数据同步装置,所述装置包括:
数据清空模块,用于获取第一业务数据,确定存储所述第一业务数据的数据源,并清空所述数据源对应的缓存组件中的第二业务数据;
数据存储模块,用于若成功清空所述数据源对应的缓存组件中的所述第二业务数据,将所述第一业务数据存储至所述数据源;
数据同步模块,用于若成功将所述第一业务数据存储至所述数据源,将所述第一业务数据同步至所述缓存组件;
状态更新模块,用于若成功将所述第一业务数据同步至所述缓存组件,更新所述第一业务数据的同步状态。
在本发明实施例的第三方面,还提供了一种电子设备,包括处理器、通信接口、存储器和通信总线,其中,处理器,通信接口,存储器通过通信总线完成相互间的通信;
存储器,用于存放计算机程序;
处理器,用于执行存储器上所存放的程序时,实现上述第一方面中任一所述的数据同步方法。
在本发明实施例的第四方面,还提供了一种存储介质,所述存储介质中存储有指令,当其在计算机上运行时,使得计算机执行上述第一方面中任一所述的数据同步方法。
在本发明实施例的第五方面,还提供了一种包含指令的计算机程序产品,当其在计算机上运行时,使得计算机执行上述第一方面中任一所述的数据同步方法。
本发明实施例提供的技术方案,获取第一业务数据,确定存储第一业务数据的数据源,清空数据源对应的缓存组件中的第二业务数据,若成功清空数据源对应的缓存组件中的第二业务数据,将第一业务数据存储至数据源,若成功将第一业务数据存储至数据源,将第一业务数据同步至缓存组件,若成功将第一业务数据同步至缓存组件,更新第一业务数据的同步状态。本发明实施例在将第一业务数据真正存储至数据源之前,清空数据源对应的缓存组件中的第二业务数据,如此缓存组件中业务数据为空,可以避免对业务产生影响,确定业务正常安全运转。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本发明的实施例,并与说明书一起用于解释本发明的原理。
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,对于本领域普通技术人员而言,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1为本发明实施例中示出的一种数据同步方法的实施流程示意图;
图2为本发明实施例中示出的一种数据源与缓存组件的对应示意图;
图3为本发明实施例中示出的另一种数据同步方法的实施流程示意图;
图4为本发明实施例中示出的另一种数据同步方法的实施流程示意图;
图5为本发明实施例中示出的另一种数据同步方法的实施流程示意图;
图6为本发明实施例中示出的另一种数据同步方法的实施流程示意图;
图7为本发明实施例中示出的一种数据同步装置的结构示意图;
图8为本发明实施例中示出的一种电子设备的结构示意图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明的一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动的前提下所获得的所有其他实施例,都属于本发明保护的范围。
如图1所示,为本发明实施例提供的一种数据同步方法的实施流程示意图,该方法可以应用于处理器,具体可以包括以下步骤:
S101,获取第一业务数据,确定存储所述第一业务数据的数据源,并清空所述数据源对应的缓存组件中的第二业务数据。
在本发明实施例中,可以由业务系统生成第一业务数据,从而获取该第一业务数据。例如由电子商务系统生成针对商品的价格、地址、图标等第一业务数据,从而可以获取该第一业务数据。
在获取到第一业务数据之后,本发明实施例需要确定存储该第一业务数据的数据源,对于数据源,可以是各种类型的数据库,本发明实施例对此不作限定。例如,对于第一业务数据,确定存储该第一业务数据的Mysql。
对于确定的数据源,本发明实施例需要确定该数据源对应的缓存组件,从而在将第一业务数据存储至数据源之前,可以首先清空缓存组件中的第二业务数据。
例如,对于Mysql,本发明实施例可以确定Mysql对应的缓存组件Redis,如图2所示,从而在将第一业务数据存储至Mysql之前,可以首先清空Redis中的第二业务数据。
需要说明的是,对于业务数据,可以是针对商品的价格、地址、图标等业务数据,当然还可以是其他业务数据,本发明实施例在此不再一一赘述。对于缓存组件,可以是Redis,可以是memcached(即一套分布式的快取系统,与Redis相似),本发明实施例对此不作限定。
S102,若成功清空所述数据源对应的缓存组件中的所述第二业务数据,将所述第一业务数据存储至所述数据源。
对于数据源对应的缓存组件中的第二业务数据,若成功清空该第二业务数据,则可以将第一业务数据存储至数据源。
例如,对于Mysql对应的Redis中的第二业务数据,若成功清空该第二业务数据,则可以将第一业务数据存储至Mysql。
S103,若成功将所述第一业务数据存储至所述数据源,将所述第一业务数据同步至所述缓存组件。
对于第一业务数据,若成功将该第一业务数据存储至数据源,则将第一业务数据同步至数据源对应的缓存组件。
例如,对于第一业务数据,若成功将该第一业务数据存储至Mysql,则将第一业务数据同步至Mysql对应的Redis。
S104,若成功将所述第一业务数据同步至所述缓存组件,更新所述第一业务数据的同步状态。
对于第一业务数据,若成功将该第一业务数据同步至数据源对应的缓存组件,可以更新该第一业务数据的同步状态,具体可以将该第一业务数据的同步状态更新为已同步,本发明实施例对此不作限定。
例如,对于第一业务数据,若成功将该第一业务数据同步至Mysql对应的Redis,可以更新该第一业务数据的同步状态,具体可以将该第一业务数据的同步状态更新为已同步。
通过上述对本发明实施例提供的技术方案的描述,获取第一业务数据,确定存储第一业务数据的数据源,清空数据源对应的缓存组件中的第二业务数据,若成功清空数据源对应的缓存组件中的第二业务数据,将第一业务数据存储至数据源,若成功将第一业务数据存储至数据源,将第一业务数据同步至缓存组件,若成功将第一业务数据同步至缓存组件,更新第一业务数据的同步状态。
本发明实施例在将第一业务数据真正存储至数据源之前,清空数据源对应的缓存组件中的第二业务数据,如此缓存组件中业务数据为空,可以避免对业务产生影响,确定业务正常安全运转。
如图3所示,为本发明实施例提供的另一种数据同步方法的实施流程示意图,该方法可以应用于处理器,具体可以包括以下步骤:
S301,获取第一业务数据,确定存储所述第一业务数据的数据源,并清空所述数据源对应的缓存组件中的第二业务数据,所述数据源包括第一数据源和第二数据源。
在本发明实施例中,可以获取第一业务数据,确定存储该第一业务数据的数据源,并清空数据源对应的缓存组件中的第二业务数据。对于数据源,具体可以包括第一数据源和第二数据源,确保在同一个事物(即数据源的保障机制)中。
对于第一数据源的作用,具体可以存储该第一业务数据,而对于第二数据源的作用,具体可以是与业务相互解耦,专门用来处理通知类事件。比如业务数据同步至Redis,发送MQ(Message Queue,消息队列)等等。
S302,若成功清空所述数据源对应的缓存组件中的所述第二业务数据,将所述第一业务数据存储至所述第一数据源。
S303,以及在所述第一数据源中提取所述第一业务数据对应的主键ID,将所述主键ID存储至所述第二数据源。
对于数据源对应的缓存组件中的第二业务数据,若成功清空该第二业务数据,则可以将第一业务数据存储至第一数据源,以及在第一数据源中提取第一业务数据对应的主键ID,将主键ID存储至第二数据源。
例如,如图4所示,对于第一Mysql、第二Mysql对应的Redis中的第二业务数据,若成功清空该第二业务数据,则可以将该第一业务数据存储至第一Mysql,以及在第一Mysql中提取第一业务数据对应的主键ID,将主键ID存储至第二Mysql。
S304,若成功将所述第一业务数据存储至所述第一数据源,将所述第一业务数据同步至所述缓存组件。
对于第一业务数据,若成功将该第一业务数据存储至第一数据源,则将第一业务数据同步至数据源对应的缓存组件。
例如,对于第一业务数据,若成功将该第一业务数据存储至第一Mysql,则将第一业务数据同步至Redis,如图4所示。
其中,对于第一业务数据,若成功将该第一业务数据存储至第一数据源,可以在第二数据源中获取第一业务数据的主键ID,根据主键ID在第一数据源查找主键ID对应的第一业务数据,将第一业务数据同步至缓存组件。
例如,对于第一业务数据,若成功将该第一业务数据存储至第一Mysql,在第二Mysql中获取第一业务数据的主键ID,根据主键ID在第一Mysql查找主键ID对应的第一业务数据,将第一业务数据同步至Redis。
S305,若成功将所述第一业务数据同步至所述缓存组件,在所述第二数据源中更新所述第一业务数据对应的所述主键ID的同步状态。
对于第一业务数据,若成功将该第一业务数据同步至数据源对应的缓存组件,在第二数据源中更新第一业务数据对应的主键ID的同步状态,具体可以将该第一业务数据对应的主键ID的同步状态更新为已同步,本发明实施例对此不作限定。如此将第一业务数据对应的主键ID的同步状态更新为已同步,可以表明第一业务数据已同步至缓存组件。
例如,对于第一业务数据,若成功将该第一业务数据同步至Redis,在第二Mysql中可以更新第一业务数据对应的主键ID的同步状态,具体可以将该第一业务数据对应的主键ID的同步状态更新为已同步,这样可以表明第一业务数据已成功同步至Redis。
此外,由于网络异常或者清空请求超时等情况的发生,导致未成功清空数据源对应的缓存组件中的第二业务数据。从而在未成功清空数据源对应的缓存组件中的第二业务数据的情况下,一方面,对于第一业务数据存储至第一数据源以及同步至缓存组件的流程中断;另一方面,由于特殊情况的存在,缓存组件中业务数据有可能丢失,可以依赖调度器,按照预设的扫描周期扫描第一数据源中的第三业务数据,判断该第三业务数据是否与缓存组件中的第二业务数据一致,若该第三业务数据与缓存组件中的第二业务数据未一致,从该第三业务数据中查找未存在于缓存组件的缺失业务数据,将该缺失业务数据同步至缓存组件;若该第三业务数据与缓存组件中的第二业务数据一致,则可以不进行任何处理。
例如,如图5所示,在未成功清空数据源对应的Redis中的第二业务数据的情况下,一方面,对于第一业务数据存储至第一Mysql以及同步至Redis的流程中断;另一方面,由于特殊情况的存在,Redis中业务数据有可能丢失,可以依赖调度器,每间隔10分钟扫描一次第一Mysql中的第三业务数据,判断该第三业务数据是否与Redis中的第二业务数据一致,若该第三业务数据是否与Redis中的第二业务数据未一致,从该第三业务数据中查找未存在于Redis的缺失业务数据,将该缺失业务数据同步至Redis,如此保证第一Mysql中业务数据与Redis中业务数据一致;若该第三业务数据与Redis中的第二业务数据一致,则可以不进行任何处理。
由于网络异常或者数据源异常等情况的发生,导致未成功将第一业务数据存储至数据源。从而在未成功将第一业务数据存储至数据源的情况下,一方面,对于第一业务数据存储至第一数据源以及同步至缓存组件的流程中断;另一方面,由于特殊情况的存在,缓存组件中业务数据有可能丢失,可以依赖调度器,按照预设的扫描周期扫描第一数据源中的第三业务数据,判断该第三业务数据是否与缓存组件中的第二业务数据一致,若该第三业务数据与缓存组件中的第二业务数据未一致,从该第三业务数据中查找未存在于缓存组件的缺失业务数据,将该缺失业务数据同步至缓存组件;若该第三业务数据与缓存组件中的第二业务数据一致,则可以不进行任何处理。
由于网络异常、缓存组件异常等情况的发生,导致未成功将第一业务数据同步至缓存组件。从而在未成功将第一业务数据同步至缓存组件的情况下,可以依赖调度器,按照预设的同步周期获取第二数据源中的主键ID;根据主键ID在第一数据源查找主键ID对应的第一业务数据,将第一业务数据同步至缓存组件;若成功将第一业务数据同步至缓存组件,在第二数据源中更新第一业务数据对应的主键ID的同步状态,具体更新为已同步,本发明实施例对此不作限定。
例如,如图6所示,在未成功将第一业务数据同步至Redis的情况下,可以依赖调度器,每间隔1秒获取一次第二Mysql中的主键ID,根据该主键ID在第一Mysql中查找该主键ID对应的第一业务数据,将第一业务数据同步至Redis,在成功将第一业务数据同步至Redis的情况下,在第二Mysql中更新第一业务数据对应的主键ID的同步状态为已同步。
其中,在高并发情况下,第一业务数据有可能被重复执行,即多次同步至缓存组件,为了避免此种情况的发生,因此在将第一业务数据同步至缓存组件之前,再次判断第一业务数据的主键ID的同步状态是否为未同步,若第一业务数据的主键ID的同步状态为未同步,将第一业务数据同步至缓存组件,否则无需将第一业务数据同步至缓存组件。
对于缓存组件,可以提供业务数据查询的功能,即当接收到业务数据查询请求中,解析业务数据查询请求中携带的数据标识;判断缓存组件中是否存在数据标识对应的目标业务数据;若缓存组件中存在数据标识对应的目标业务数据,将目标业务数据返回至业务数据查询请求的发出者;若缓存组件中未存在数据标识对应的目标业务数据,向业务数据查询请求的发出者返回业务数据查询失败的消息。
这里,在缓存组件中未存在数据标识对应的目标业务数据的情况下,向业务数据查询请求的发出者返回业务数据查询失败的消息,完全依赖于缓存组件,并不会将业务数据查询请求降级到第一数据源,原因在于如果在极端情况下,TPS(Transaction PerSecond,每秒事务处理量)很大且Redis也宕机了,那么全部业务数据查询请求降级到第一数据源,有可能造成第一数据源也宕机,这将会给整个业务带来毁灭性灾害。
与上述方法实施例相对应,本发明实施例还提供了一种数据同步装置,如图7所示,该装置可以包括:数据清空模块710、数据存储模块720、数据同步模块730、状态更新模块740。
数据清空模块710,用于获取第一业务数据,确定存储所述第一业务数据的数据源,并清空所述数据源对应的缓存组件中的第二业务数据;
数据存储模块720,用于若成功清空所述数据源对应的缓存组件中的所述第二业务数据,将所述第一业务数据存储至所述数据源;
数据同步模块730,用于若成功将所述第一业务数据存储至所述数据源,将所述第一业务数据同步至所述缓存组件;
状态更新模块740,用于若成功将所述第一业务数据同步至所述缓存组件,更新所述第一业务数据的同步状态。
在本发明实施例的具体实施方式中,所述数据源包括第一数据源和第二数据源;
所述数据存储模块720具体用于:
若成功清空所述数据源对应的缓存组件中的所述第二业务数据,将所述第一业务数据存储至所述第一数据源;以及,
在所述第一数据源中提取所述第一业务数据对应的主键ID,将所述主键ID存储至所述第二数据源。
在本发明实施例的具体实施方式中,所述状态更新模块740具体用于:
若成功将所述第一业务数据同步至所述缓存组件,在所述第二数据源中更新所述第一业务数据对应的所述主键ID的同步状态。
在本发明实施例的具体实施方式中,所述装置还包括:
缺失业务数据同步模块,用于若未成功清空所述数据源对应的缓存组件中的所述第二业务数据,或者,若未成功将所述第一业务数据存储至所述数据源,按照预设的扫描周期扫描所述第一数据源中的第三业务数据;
判断所述第三业务数据是否与所述缓存组件中的所述第二业务数据一致;
若所述第三业务数据与所述缓存组件中的所述第二业务数据未一致,从所述第三业务数据中查找未存在于所述缓存组件的缺失业务数据;
将所述缺失业务数据同步至所述缓存组件。
在本发明实施例的具体实施方式中,所述装置还包括:
主键ID获取模块,用于若未成功将所述第一业务数据同步至所述缓存组件,按照预设的同步周期获取所述第二数据源中的所述主键ID;
数据查找模块,用于根据所述主键ID在所述第一数据源查找所述主键ID对应的所述第一业务数据,将所述第一业务数据同步至所述缓存组件;
同步状态更新模块,用于若成功将所述第一业务数据同步至所述缓存组件,在所述第二数据源中更新所述第一业务数据对应的所述主键ID的同步状态。
在本发明实施例的具体实施方式中,所述数据查找模块具体用于:
根据所述主键ID在所述第一数据源查找所述主键ID对应的所述第一业务数据,判断所述主键ID的同步状态是否为未同步;
若所述主键ID的同步状态为未同步,将所述第一业务数据同步至所述缓存组件。
在本发明实施例的具体实施方式中,所述装置还包括:
业务数据查询模块,用于当接收到业务数据查询请求中,解析所述业务数据查询请求中携带的数据标识;
判断所述缓存组件中是否存在所述数据标识对应的目标业务数据;
若所述缓存组件中存在所述数据标识对应的目标业务数据,将所述目标业务数据返回至所述业务数据查询请求的发出者;
若所述缓存组件中未存在所述数据标识对应的目标业务数据,向所述业务数据查询请求的发出者返回业务数据查询失败的消息。
本发明实施例还提供了一种电子设备,如图8所示,包括处理器81、通信接口82、存储器83和通信总线84,其中,处理器81,通信接口82,存储器83通过通信总线84完成相互间的通信,
存储器83,用于存放计算机程序;
处理器81,用于执行存储器83上所存放的程序时,实现如下步骤:
获取第一业务数据,确定存储所述第一业务数据的数据源,并清空所述数据源对应的缓存组件中的第二业务数据;若成功清空所述数据源对应的缓存组件中的所述第二业务数据,将所述第一业务数据存储至所述数据源;若成功将所述第一业务数据存储至所述数据源,将所述第一业务数据同步至所述缓存组件;若成功将所述第一业务数据同步至所述缓存组件,更新所述第一业务数据的同步状态。
上述电子设备提到的通信总线可以是外设部件互连标准(Peripheral ComponentInterconnect,简称PCI)总线或扩展工业标准结构(Extended Industry StandardArchitecture,简称EISA)总线等。该通信总线可以分为地址总线、数据总线、控制总线等。为便于表示,图中仅用一条粗线表示,但并不表示仅有一根总线或一种类型的总线。
通信接口用于上述电子设备与其他设备之间的通信。
存储器可以包括随机存取存储器(Random Access Memory,简称RAM),也可以包括非易失性存储器(non-volatile memory),例如至少一个磁盘存储器。可选的,存储器还可以是至少一个位于远离前述处理器的存储装置。
上述的处理器可以是通用处理器,包括中央处理器(Central Processing Unit,简称CPU)、网络处理器(Network Processor,简称NP)等;还可以是数字信号处理器(Digital Signal Processing,简称DSP)、专用集成电路(Application SpecificIntegrated Circuit,简称ASIC)、现场可编程门阵列(Field-Programmable Gate Array,简称FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。
在本发明提供的又一实施例中,还提供了一种存储介质,该存储介质中存储有指令,当其在计算机上运行时,使得计算机执行上述实施例中任一所述的数据同步方法。
在本发明提供的又一实施例中,还提供了一种包含指令的计算机程序产品,当其在计算机上运行时,使得计算机执行上述实施例中任一所述的数据同步方法。
在上述实施例中,可以全部或部分地通过软件、硬件、固件或者其任意组合来实现。当使用软件实现时,可以全部或部分地以计算机程序产品的形式实现。所述计算机程序产品包括一个或多个计算机指令。在计算机上加载和执行所述计算机程序指令时,全部或部分地产生按照本发明实施例所述的流程或功能。所述计算机可以是通用计算机、专用计算机、计算机网络、或者其他可编程装置。所述计算机指令可以存储在存储介质中,或者从一个存储介质向另一个存储介质传输,例如,所述计算机指令可以从一个网站站点、计算机、服务器或数据中心通过有线(例如同轴电缆、光纤、数字用户线(DSL))或无线(例如红外、无线、微波等)方式向另一个网站站点、计算机、服务器或数据中心进行传输。所述存储介质可以是计算机能够存取的任何可用介质或者是包含一个或多个可用介质集成的服务器、数据中心等数据存储设备。所述可用介质可以是磁性介质,(例如,软盘、硬盘、磁带)、光介质(例如,DVD)、或者半导体介质(例如固态硬盘Solid State Disk(SSD))等。
需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
本说明书中的各个实施例均采用相关的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于系统实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
以上所述仅为本发明的较佳实施例而已,并非用于限定本发明的保护范围。凡在本发明的精神和原则之内所作的任何修改、等同替换、改进等,均包含在本发明的保护范围内。

Claims (10)

1.一种数据同步方法,其特征在于,所述方法包括:
获取第一业务数据,确定存储所述第一业务数据的数据源,并清空所述数据源对应的缓存组件中的第二业务数据,所述数据源包括第一数据源和第二数据源;
若成功清空所述数据源对应的缓存组件中的所述第二业务数据,将所述第一业务数据存储至所述数据源,包括:若成功清空所述数据源对应的缓存组件中的所述第二业务数据,将所述第一业务数据存储至所述第一数据源;
若未成功清空数据源对应的缓存组件中的第二业务数据,中断第一业务数据存储至第一数据源以及同步至缓存组件的流程;按照预设的扫描周期扫描第一数据源中的第三业务数据,判断该第三业务数据是否与缓存组件中的第二业务数据一致,若该第三业务数据与缓存组件中的第二业务数据未一致,从该第三业务数据中查找未存在于缓存组件的缺失业务数据,将该缺失业务数据同步至缓存组件;
若成功将所述第一业务数据存储至所述数据源,将所述第一业务数据同步至所述缓存组件;
若成功将所述第一业务数据同步至所述缓存组件,更新所述第一业务数据的同步状态。
2.根据权利要求1所述的方法,其特征在于,
所述若成功清空所述数据源对应的缓存组件中的所述第二业务数据,将所述第一业务数据存储至所述数据源,包括:
在所述第一数据源中提取所述第一业务数据对应的主键ID,将所述主键ID存储至所述第二数据源。
3.根据权利要求2所述的方法,其特征在于,所述若成功将所述第一业务数据同步至所述缓存组件,更新所述第一业务数据的同步状态,包括:
若成功将所述第一业务数据同步至所述缓存组件,在所述第二数据源中更新所述第一业务数据对应的所述主键ID的同步状态。
4.根据权利要求2所述的方法,其特征在于,所述方法还包括:
若未成功清空所述数据源对应的缓存组件中的所述第二业务数据,或者,若未成功将所述第一业务数据存储至所述数据源,按照预设的扫描周期扫描所述第一数据源中的第三业务数据;
判断所述第三业务数据是否与所述缓存组件中的所述第二业务数据一致;
若所述第三业务数据与所述缓存组件中的所述第二业务数据未一致,从所述第三业务数据中查找未存在于所述缓存组件的缺失业务数据;
将所述缺失业务数据同步至所述缓存组件。
5.根据权利要求2所述的方法,其特征在于,所述方法还包括:
若未成功将所述第一业务数据同步至所述缓存组件,按照预设的同步周期获取所述第二数据源中的所述主键ID;
根据所述主键ID在所述第一数据源查找所述主键ID对应的所述第一业务数据,将所述第一业务数据同步至所述缓存组件;
若成功将所述第一业务数据同步至所述缓存组件,在所述第二数据源中更新所述第一业务数据对应的所述主键ID的同步状态。
6.根据权利要求5所述的方法,其特征在于,所述根据所述主键ID在所述第一数据源查找所述主键ID对应的所述第一业务数据,将所述第一业务数据同步至所述缓存组件,包括:
根据所述主键ID在所述第一数据源查找所述主键ID对应的所述第一业务数据,判断所述主键ID的同步状态是否为未同步;
若所述主键ID的同步状态为未同步,将所述第一业务数据同步至所述缓存组件。
7.根据权利要求1至6任一项所述的方法,其特征在于,所述方法还包括:
当接收到业务数据查询请求中,解析所述业务数据查询请求中携带的数据标识;
判断所述缓存组件中是否存在所述数据标识对应的目标业务数据;
若所述缓存组件中存在所述数据标识对应的目标业务数据,将所述目标业务数据返回至所述业务数据查询请求的发出者;
若所述缓存组件中未存在所述数据标识对应的目标业务数据,向所述业务数据查询请求的发出者返回业务数据查询失败的消息。
8.一种数据同步装置,其特征在于,所述装置包括:
数据清空模块,用于获取第一业务数据,确定存储所述第一业务数据的数据源,并清空所述数据源对应的缓存组件中的第二业务数据,所述数据源包括第一数据源和第二数据源;
数据存储模块,用于若成功清空所述数据源对应的缓存组件中的所述第二业务数据,将所述第一业务数据存储至所述数据源,包括:若成功清空所述数据源对应的缓存组件中的所述第二业务数据,将所述第一业务数据存储至所述第一数据源;若未成功清空数据源对应的缓存组件中的第二业务数据,中断第一业务数据存储至第一数据源以及同步至缓存组件的流程;按照预设的扫描周期扫描第一数据源中的第三业务数据,判断该第三业务数据是否与缓存组件中的第二业务数据一致,若该第三业务数据与缓存组件中的第二业务数据未一致,从该第三业务数据中查找未存在于缓存组件的缺失业务数据,将该缺失业务数据同步至缓存组件;
数据同步模块,用于若成功将所述第一业务数据存储至所述数据源,将所述第一业务数据同步至所述缓存组件;
状态更新模块,用于若成功将所述第一业务数据同步至所述缓存组件,更新所述第一业务数据的同步状态。
9.一种电子设备,其特征在于,包括处理器、通信接口、存储器和通信总线,其中,处理器,通信接口,存储器通过通信总线完成相互间的通信;
存储器,用于存放计算机程序;
处理器,用于执行存储器上所存放的程序时,实现权利要求1-7中任一所述的方法步骤。
10.一种存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1-7中任一所述的方法。
CN202110057596.9A 2021-01-15 2021-01-15 数据同步方法、装置、电子设备及存储介质 Active CN112749233B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202110057596.9A CN112749233B (zh) 2021-01-15 2021-01-15 数据同步方法、装置、电子设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202110057596.9A CN112749233B (zh) 2021-01-15 2021-01-15 数据同步方法、装置、电子设备及存储介质

Publications (2)

Publication Number Publication Date
CN112749233A CN112749233A (zh) 2021-05-04
CN112749233B true CN112749233B (zh) 2024-05-17

Family

ID=75652257

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202110057596.9A Active CN112749233B (zh) 2021-01-15 2021-01-15 数据同步方法、装置、电子设备及存储介质

Country Status (1)

Country Link
CN (1) CN112749233B (zh)

Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106997378A (zh) * 2017-03-13 2017-08-01 摩贝(上海)生物科技有限公司 基于Redis的数据库数据聚合同步的方法
CN108304408A (zh) * 2017-01-12 2018-07-20 中国移动通信集团公司 一种缓存数据刷新方法及装置
CN109491862A (zh) * 2018-10-24 2019-03-19 聚好看科技股份有限公司 一种基于云平台的业务请求信息收集方法及装置
CN109800272A (zh) * 2019-02-25 2019-05-24 广州虎牙信息科技有限公司 缓存数据同步方法、服务器、应用系统及存储装置
CN109885786A (zh) * 2019-01-23 2019-06-14 聚好看科技股份有限公司 数据缓存处理方法、装置、电子设备及可读存储介质
CN110209677A (zh) * 2018-02-06 2019-09-06 北京京东尚科信息技术有限公司 更新数据的方法和装置
CN110908838A (zh) * 2019-11-19 2020-03-24 杭州安恒信息技术股份有限公司 一种数据处理方法、装置及电子设备和存储介质
CN111078717A (zh) * 2019-12-20 2020-04-28 深圳前海环融联易信息科技服务有限公司 数据库与缓存的一致性同步方法、装置、计算机设备及存储介质
CN111414424A (zh) * 2020-03-23 2020-07-14 北京思特奇信息技术股份有限公司 一种配置数据自动同步redis的方法、系统、介质及设备

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10891302B2 (en) * 2018-01-08 2021-01-12 Accenture Global Solutions Limited Scalable synchronization with cache and index management

Patent Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN108304408A (zh) * 2017-01-12 2018-07-20 中国移动通信集团公司 一种缓存数据刷新方法及装置
CN106997378A (zh) * 2017-03-13 2017-08-01 摩贝(上海)生物科技有限公司 基于Redis的数据库数据聚合同步的方法
CN110209677A (zh) * 2018-02-06 2019-09-06 北京京东尚科信息技术有限公司 更新数据的方法和装置
CN109491862A (zh) * 2018-10-24 2019-03-19 聚好看科技股份有限公司 一种基于云平台的业务请求信息收集方法及装置
CN109885786A (zh) * 2019-01-23 2019-06-14 聚好看科技股份有限公司 数据缓存处理方法、装置、电子设备及可读存储介质
CN109800272A (zh) * 2019-02-25 2019-05-24 广州虎牙信息科技有限公司 缓存数据同步方法、服务器、应用系统及存储装置
CN110908838A (zh) * 2019-11-19 2020-03-24 杭州安恒信息技术股份有限公司 一种数据处理方法、装置及电子设备和存储介质
CN111078717A (zh) * 2019-12-20 2020-04-28 深圳前海环融联易信息科技服务有限公司 数据库与缓存的一致性同步方法、装置、计算机设备及存储介质
CN111414424A (zh) * 2020-03-23 2020-07-14 北京思特奇信息技术股份有限公司 一种配置数据自动同步redis的方法、系统、介质及设备

Also Published As

Publication number Publication date
CN112749233A (zh) 2021-05-04

Similar Documents

Publication Publication Date Title
CN108228814B (zh) 数据同步方法及装置
EP3791284A1 (en) Conflict resolution for multi-master distributed databases
US7933866B2 (en) Systems, methods and software programs for data synchronization
US10122598B2 (en) Subscription watch lists for event handling
CN109450969B (zh) 从第三方数据源服务器中获取数据的方法、装置和服务器
EP2674868A1 (en) Database update notification method
CN112445626A (zh) 一种基于消息中间件的数据处理方法和装置
CN111666134A (zh) 一种分布式任务调度的方法和系统
CN112749233B (zh) 数据同步方法、装置、电子设备及存储介质
CN110674153B (zh) 一种数据一致性检测方法、装置及电子设备
CN113127564A (zh) 一种参数同步方法和装置
CN113645260A (zh) 业务重试方法、装置、存储介质及电子设备
CN111488117B (zh) 用于管理元数据的方法、电子设备和计算机可读介质
CN108959548B (zh) 业务请求的处理方法及装置
CN110955460A (zh) 一种服务进程启动方法、装置、电子设备和存储介质
CN116701020A (zh) 消息延时处理方法、装置、设备、介质和程序产品
CN114077587A (zh) 基于规则引擎的业务处理方法、规则引擎、介质和设备
CN112765188A (zh) 配置信息处理方法、配置管理系统、电子设备及存储介质
CN112463887A (zh) 一种数据处理方法、装置、设备及存储介质
CN113742355A (zh) 更新库存的方法、装置、设备和计算机可读介质
CN112182003A (zh) 一种数据同步方法和装置
CN111008202A (zh) 分布式事务处理方法和框架
CN112783903A (zh) 生成更新日志的方法和装置
CN112732728A (zh) 一种数据同步方法和系统
CN114900531B (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
CB02 Change of applicant information

Address after: Room 221, 2 / F, block C, 18 Kechuang 11th Street, Daxing District, Beijing, 100176

Applicant after: Jingdong Technology Holding Co.,Ltd.

Address before: Room 221, 2 / F, block C, 18 Kechuang 11th Street, Daxing District, Beijing, 100176

Applicant before: Jingdong Digital Technology Holding Co.,Ltd.

CB02 Change of applicant information
GR01 Patent grant
GR01 Patent grant