CN110209512B - 基于多数据源的数据核对方法及装置 - Google Patents

基于多数据源的数据核对方法及装置 Download PDF

Info

Publication number
CN110209512B
CN110209512B CN201910465750.9A CN201910465750A CN110209512B CN 110209512 B CN110209512 B CN 110209512B CN 201910465750 A CN201910465750 A CN 201910465750A CN 110209512 B CN110209512 B CN 110209512B
Authority
CN
China
Prior art keywords
data
change message
data change
executed
queue
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.)
Expired - Fee Related
Application number
CN201910465750.9A
Other languages
English (en)
Other versions
CN110209512A (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.)
Koubei Shanghai Information Technology Co Ltd
Original Assignee
Koubei Shanghai Information Technology 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 Koubei Shanghai Information Technology Co Ltd filed Critical Koubei Shanghai Information Technology Co Ltd
Priority to CN201910465750.9A priority Critical patent/CN110209512B/zh
Publication of CN110209512A publication Critical patent/CN110209512A/zh
Application granted granted Critical
Publication of CN110209512B publication Critical patent/CN110209512B/zh
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

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/24Querying
    • G06F16/245Query processing
    • G06F16/2457Query processing with adaptation to user needs
    • G06F16/24578Query processing with adaptation to user needs using ranking
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/546Message passing systems or structures, e.g. queues

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Software Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Computational Linguistics (AREA)
  • Data Mining & Analysis (AREA)
  • Databases & Information Systems (AREA)
  • Debugging And Monitoring (AREA)

Abstract

本发明公开了一种基于多数据源的数据核对方法及装置。其中,方法包括:监听来自多个数据源的数据变更消息;确定当前待执行队列中是否存在与数据变更消息对应的上游数据;若存在,则从待执行队列中获取与数据变更消息对应的上游数据,并执行上游数据与数据变更消息的数据核对;若不存在,则触发与数据变更消息对应的数据核对请求,并将数据变更消息添加至所述待执行队列。采用本方案可以避免现有技术中出现的数据核对存在较大核对延迟的弊端,提升核对数据的处理效率。

Description

基于多数据源的数据核对方法及装置
技术领域
本发明涉及计算机技术领域,具体涉及一种基于多数据源的数据核对方法及装置。
背景技术
随着互联网技术的飞速发展,各类业务处理效率也随之不断提升,从而极大方便了人们的工作与生活。在业务处理过程中,通常会涉及业务数据的流转。目前,为避免业务数据流转异常而引起的用户资源损失,通常需在数据流转过程中进行数据核对操作。例如,在银行、第三方支付平台、或其他涉及物品交易的各类平台中,通常需要进行账账核对、账证核对、系统间的核对、系统间各节点的核对等针对业务处理的核对操作,从而保障业务流水等的准确性。
目前在进行数据的核对过程中,通常采用的核对方式为业务系统在线核对的方式(如公布号为CN103136276A的中国发明专利申请,是通过实时地查找对应的线上数据库的方式实现数据的核对)。在该核对方式中,具体是针对于接收到的核对请求,从某数据源中获取数据核对的上游数据,并从另一数据源中获取数据核对的下游数据。由于在实际的实施过程中,数据流转存在一定的延时,从而为了避免因获取的下游数据不是最新的下游数据而带来的数据核对噪音,通常需在获取上游数据之后,经过预设时间后再获取该下游数据。从中可以看出,该种核对方式数据核对效率极为低下。
发明内容
鉴于上述问题,提出了本发明以便提供一种克服上述问题或者至少部分地解决上述问题的基于多数据源的数据核对方法及装置。
根据本发明的一个方面,提供了一种基于多数据源的数据核对方法,包括:
监听来自多个数据源的数据变更消息;
确定当前待执行队列中是否存在与所述数据变更消息对应的上游数据;
若存在,则从所述待执行队列中获取与所述数据变更消息对应的上游数据,并执行所述上游数据与所述数据变更消息的数据核对;
若不存在,则触发与所述数据变更消息对应的数据核对请求,并将所述数据变更消息添加至所述待执行队列。
可选的,所述确定当前待执行队列中是否存在与所述数据变更消息对应的上游数据进一步包括:
获取所述数据变更消息对应的唯一键;
根据所述数据变更消息对应的唯一键,确定当前待执行队列中是否存在与所述数据变更消息对应的上游数据。
可选的,所述获取所述数据变更消息对应的唯一键进一步包括:
确定与所述数据变更消息对应的核对规则;
根据所述与所述数据变更消息对应的核对规则,确定与所述数据变更消息对应的唯一键确定方式;
采用所述唯一键确定方式,确定与所述数据变更消息对应的唯一键。
可选的,所述方法还包括:
监测所述待执行队列中各数据的等待时间;
将待执行队列中等待时间超出预设阈值的数据标记为异常数据,并采用相应的异常数据处理方法,对所述异常数据进行处理。
可选的,所述触发与所述数据变更消息对应的数据核对请求,并将所述数据变更消息添加至所述待执行队列进一步包括:
确定与所述数据变更消息对应的核对规则的数目;
根据与所述数据变更消息对应的核对规则的数目,确定触发的与所述数据变更消息对应的数据核对请求的数目。
可选的,若确定与所述数据变更消息对应的上游数据对应的数据核对请求数目为1,则在从所述待执行队列中获取与所述数据变更消息对应的上游数据之后,所述方法还包括:
将所述上游数据从所述待执行队列中删除。
可选的,所述监听来自多个数据源的数据变更消息进一步包括:
确定与核对规则对应的多个数据源,针对于所述多个数据源中的每个数据源,当该数据源中发生目标数据变更时,生成与所述目标数据变更对应的数据变更消息;
订阅所述多个数据源的数据变更消息。
根据本发明的另一方面,提供了一种基于多数据源的数据核对装置,包括:
监听模块,适于监听来自多个数据源的数据变更消息;
确定模块,适于确定当前待执行队列中是否存在与所述数据变更消息对应的上游数据;
核对模块,适于若确定当前待执行队列中存在与所述数据变更消息对应的上游数据,则从所述待执行队列中获取与所述数据变更消息对应的上游数据,并执行所述上游数据与所述数据变更消息的数据核对;
添加模块,适于若确定当前待执行队列中不存在与所述数据变更消息对应的上游数据,则触发与所述数据变更消息对应的数据核对请求,并将所述数据变更消息添加至所述待执行队列。
可选的,所述确定模块进一步适于:
获取所述数据变更消息对应的唯一键;
根据所述数据变更消息对应的唯一键,确定当前待执行队列中是否存在与所述数据变更消息对应的上游数据。
可选的,所述确定模块进一步适于:
确定与所述数据变更消息对应的核对规则;
根据所述与所述数据变更消息对应的核对规则,确定与所述数据变更消息对应的唯一键确定方式;
采用所述唯一键确定方式,确定与所述数据变更消息对应的唯一键。
可选的,所述装置还包括:
异常数据处理模块,适于监测所述待执行队列中各数据的等待时间;
将待执行队列中等待时间超出预设阈值的数据标记为异常数据,并采用相应的异常数据处理方法,对所述异常数据进行处理。
可选的,所述添加模块进一步适于:确定与所述数据变更消息对应的核对规则的数目;
根据与所述数据变更消息对应的核对规则的数目,确定触发的与所述数据变更消息对应的数据核对请求的数目。
可选的,若确定与所述数据变更消息对应的上游数据对应的数据核对请求数目为1,则在从所述待执行队列中获取与所述数据变更消息对应的上游数据之后,所述装置还包括:
删除模块,适于将所述上游数据从所述待执行队列中删除。
可选的,所述监听模块进一步适于:确定与核对规则对应的多个数据源,针对于所述多个数据源中的每个数据源,当该数据源中发生目标数据变更时,生成与所述目标数据变更对应的数据变更消息;
订阅所述多个数据源的数据变更消息。
根据本发明的又一方面,提供了一种计算设备,包括:处理器、存储器、通信接口和通信总线,所述处理器、所述存储器和所述通信接口通过所述通信总线完成相互间的通信;
所述存储器用于存放至少一可执行指令,所述可执行指令使所述处理器执行上述基于多数据源的数据核对方法对应的操作。
根据本发明的再一方面,提供了一种计算机存储介质,所述存储介质中存储有至少一可执行指令,所述可执行指令使处理器执行如上述基于多数据源的数据核对方法对应的操作。
根据本发明提供的基于多数据源的数据核对方法及装置,首先监听来自多个数据源的数据变更消息;进一步确定当前待执行队列中是否存在与数据变更消息对应的上游数据;若存在,则从待执行队列中获取与数据变更消息对应的上游数据,并执行上游数据与数据变更消息的数据核对;若不存在,则触发与数据变更消息对应的数据核对请求,并将数据变更消息添加至所述待执行队列。采用本方案可以避免现有技术中出现的数据核对存在较大的核对延迟的弊端,提升核对数据的处理效率。
上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。
附图说明
通过阅读下文优选实施方式的详细描述,各种其他的优点和益处对于本领域普通技术人员将变得清楚明了。附图仅用于示出优选实施方式的目的,而并不认为是对本发明的限制。而且在整个附图中,用相同的参考符号表示相同的部件。在附图中:
图1示出了根据本发明一个实施例提供的一种基于多数据源的数据核对方法的流程示意图;
图2示出了根据本发明另一个实施例提供的一种基于多数据源的数据核对方法的流程示意图;
图3示出了根据本发明一个实施例提供的一种基于多数据源的数据核对装置的功能结构示意图;
图4示出了根据本发明一个实施例提供的一种计算设备的结构示意图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
图1示出了根据本发明一个实施例提供的一种基于多数据源的数据核对方法。其中,本实施例提供的基于多数据源的数据核对方法由预设的数据核对系统执行。
如图1所示,该方法包括:
步骤S110,监听来自多个数据源的数据变更消息。
不同于现有技术中周期性地调用数据库接口来获取核对数据,本实施例是实时监听来自多个数据源的数据变更消息,从而能够及时地获取数据核对所需的数据信息,保障数据核对的准确性,降低数据核对的噪音,并能够减少线上业务系统压力,提升业务系统处理效率。
可选的,监听来自多个数据源的数据变更消息具体由以下步骤实现:确定与核对规则对应的多个数据源,针对于多个数据源中的每个数据源,当该数据源中发生目标数据变更时,生成与目标数据变更对应的数据变更消息;订阅该多个数据源的数据变更消息。
具体地,先确定与核对规则对应的多个数据源:在现有技术中,通常是由业务系统接收每一次的数据核对请求,通过分析该数据核对请求中的核对信息,来确定此次数据核对所需的数据,从而调用相应的数据库接口来获取相应的核对数据进行数据核对。本实施例则不同于现有技术中的该操作方式,本实施例具体是先获取核对规则,该核对规则是为数据核对而进行配置的。其中,获取到的核对规则可以为一条,也可以为多条,本实施例对此不做限定。进一步地,在获取到核对规则之后,根据该核对规则来确定与核对规则对应的多个数据源。其中,该核对规则中包含了核对过程中进行核对的数据源信息及具体的核对方式,从而在具体的实施过程中,可根据字段解析等方式自动地确定与核对规则对应的多个数据源。进一步针对于多个数据源中的每个数据源,当该数据源中发生目标数据变更时,生成与目标数据变更对应的数据变更消息。并由该预设的数据核对系统对多个数据源的数据变更消息实现订阅,从而能够及时地获取与核对规则对应的核对数据的变化。
步骤S120,确定当前待执行队列中是否存在与数据变更消息对应的上游数据;若是,则执行步骤S130;若否,则执行步骤S140。
为了能够快速地实现数据核对,本实施例中设置有待执行队列。其中,该待执行队列中记录有待进行数据核对的上游数据。在监听到来自多个数据源的数据变更消息时,针对于该数据变更消息,确定当前待执行队列中是否存在于该数据变更消息对应的上游数据。
若当前待执行队列中存在与数据变更消息对应的上游数据,则执行步骤S130;若当前待执行队列中不存在与数据变更消息对应的上游数据,则执行步骤S140。
步骤S130,从待执行队列中获取与该数据变更消息对应的上游数据,并执行该上游数据与该数据变更消息的数据核对。
若当前待执行队列中存在与数据变更消息对应的上游数据,则从该待执行队列中获取与该数据变更消息对应的上游数据,并执行该上游数据与该数据变更消息的数据核对。从而在监听到下游数据时,能够通过下游数据反向通知上游数据的方式,及时触发上游数据与下游数据的数据核对,进而在获得的下游数据为最新的下游数据,从而降低数据核对噪音的前提下,进一步地提升了数据核对的效率。
步骤S140,触发与数据变更消息对应的数据核对请求,并将数据变更消息添加至待执行队列。
若当前待执行队列中不存在与数据变更消息对应的上游数据,则表明该数据变更消息为某一核对规则所对应的上游数据,则触发与该数据变更消息对应的数据核对请求,并将该数据变更消息作为该数据核对请求的上游数据添加至该待执行队列中。
由此可见,本实施例监听来自多个数据源的数据变更消息,从而可及时获取核对数据对应的数据信息,并由预设的数据核对系统执行,避免了业务系统线上的处理压力,有利于业务系统处理效率的提升;并且本实施例并非采用现有技术中定时触发数据核对的方式,而是在当前待执行队列中不存在与数据变更消息对应的上游数据,触发与该数据变更消息对应的数据核对请求,并将数据变更消息添加至待执行队列;在确定当前待执行队列中存在与数据变更消息对应的上游数据时,从待执行队列中获取与数据变更消息对应的上游数据,并执行上游数据与数据变更消息的数据核对,及时触发上游数据与下游数据的数据核对,进而在获得的下游数据为最新的下游数据,从而降低数据核对噪音的前提下,进一步地提升了数据核对的效率。
图2示出了根据本发明另一个实施例提供的一种基于多数据源的数据核对方法。本实施例提供的基于多数据源的数据核对方法是针对于图1所示方法实施例的进一步优化。如图2所示,该方法包括:
步骤S210,监听来自多个数据源的数据变更消息。
具体地,确定与核对规则对应的多个数据源,针对于多个数据源中的每个数据源,当该数据源中目标数据发生变更时,根据变更后的目标数据快照信息,生成与目标数据变更对应的数据变更消息。
针对于与核对规则对应的多个数据源中的每个数据源,确定该数据源中的目标数据。在具体的实施过程中,可根据核对规则,确定目标数据所对应的数据维度。其中,该目标数据所对应的数据维度包括以下数据维度的至少一种:数据表维度、单条数据维度、和/或数据库维度等等。即本实施例中针对于每个核对规则,通过对该核对规则的数据源字段的自动解析,自动分析出与该核对规则所匹配的数据维度,从而便于提升后续数据核对的效率。
进一步地,当该数据源中目标数据发生变更时,根据变更后的目标数据的快照信息,生成与目标数据变更对应的数据变更消息。在确定与核对规则对应的多个数据源中的目标数据之后,每当该数据源中目标数据发生变更时,获取变更后的目标数据的快照信息,其中,本实施例对具体的快照信息获取方式不做限定,本领域技术人员可根据的实际情况选择相应的快照信息生成方式。进一步地,根据变更后的目标数据的快照信息,生成与目标数据变更对应的数据变更消息。即生成的数据变更消息为当前目标数据的最新数据状态,从而保障后续数据核对的准确性,降低数据核对噪音。
可选的,为避免后续目标存储空间中出现较多的冗余数据,本步骤中生成的数据变更消息中还包含有与该数据变更消息对应的目标数据的变更时间。
最终通过由预设的数据核对系统对多个数据源的数据变更消息实现订阅,从而能够及时地获取与核对规则对应的核对数据的变化。本实施例对具体的订阅方式不做限定。
步骤S220,获取与数据变更消息对应的唯一键。
为了避免出现较多的数据冗余,提升数据核对效率,本实施例具体对数据变更消息设置有对应的唯一键,即待执行队列中记录的上游数据也具有相对应的唯一键。
在具体的实施过程中,确定与数据变更消息对应的唯一键时,可先确定与数据变更消息对应的核对规则,进而根据与数据变更消息对应的核对规则,确定与数据变更消息对应的唯一键确定方式,最终采用该唯一键确定方式,确定与数据变更消息对应的唯一键。通过该种唯一键的确定方式,可实时地根据核对规则的变化来动态地调整或确定唯一键的确定方式,进而动态调整与数据变更消息对应的唯一键,从而实现数据与核对规则的强联系,进一步地提升了数据核对的准确性,避免数据核对噪音的发生;并且,能够在数据核对过程中,根据核对规则准确快速地获取所需的核对数据,进一步提升数据核对效率。另外,也可依据数据变更消息中的业务表标识、业务主键、和/或业务ID,确定数据变更消息对应的唯一键。例如,将业务表标识、业务主键、和/或业务ID的拼接字段进行哈希运算之后获得的结果确定为与该数据变更消息所对应的唯一键。
步骤S230,根据数据变更消息对应的唯一键,确定当前待执行队列中是否存在与该数据变更消息对应的上游数据;若是,则执行步骤S240;否则,执行步骤S250。
根据数据变更消息对应的唯一键,可快速准确地确定出当前待执行队列中是否存在与该数据变更消息对应的上游数据。在具体的实施过程中,可通过步骤S220中描述的数据变更消息对应的唯一键的确定方式,确定当前待执行队列中上游数据的唯一键,进而通过当前待执行队列中上游数据对应的唯一键,与该数据变更消息对应的唯一键是否匹配,来判断当前待执行队列中是否存在与该数据变更消息对应的上游数据。
若当前待执行队列中存在与数据变更消息对应的上游数据,则执行步骤S240;若当前待执行队列中不存在与数据变更消息对应的上游数据,则执行步骤S250。
步骤S240,从待执行队列中获取与数据变更消息对应的上游数据,并利用与该上游数据对应的核对规则,执行上游数据与数据变更消息的数据核对。
若当前待执行队列中存在与数据变更消息对应的上游数据,通过下游数据反向通知上游数据的方式,及时触发上游数据与下游数据的数据核对,进而在获得的下游数据为最新的下游数据,从而降低数据核对噪音的前提下,进一步地提升了数据核对的效率。
步骤S250,触发与数据变更消息对应的数据核对请求,并将数据变更消息添加至待执行队列。
若当前待执行队列中不存在与数据变更消息对应的上游数据,则表明该数据变更消息为某一核对规则所对应的上游数据,则触发与该数据变更消息对应的数据核对请求,并将该数据变更消息作为该数据核对请求的上游数据添加至该待执行队列中。
结合步骤S240及步骤S250可知,本实施例是仅在获取上游数据时触发数据核对请求,而在获取下游数据时执行该数据核对请求。
在一种可选的实施方式中,为了避免异常数据对其他数据的核对过程的干扰,本实施例中还监测待执行队列中各数据的等待时间,并将待执行队列中等待时间超出预设阈值的数据标记为异常数据,并采用相应的异常数据处理方法,对异常数据进行处理。其中,本实施例对异常数据的处理方式不做限定,例如可以将该异常数据从待执行队列中删除。举例来说,若预设阈值为10s,若某一上游数据至添加至待执行队列到当前时间的时间间隔(即在待执行队列中的等待时间)大于10s,则将该上游数据从该待执行队列中删除,并反馈相应的异常信息。
在又一种可选的实施方式中,某一数据可对应于多种核对规则,则存在某一数据为多种核对规则对应的上游数据。针对于该种情形,为保障数据核对的正常实施,本实施例在触发与数据变更消息对应的数据核对请求,并将数据变更消息添加至待执行队列过程时,可确定该数据变更消息对应的核对规则的数目,根据与数据变更消息对应的核对规则的数目,确定触发的与数据变更消息对应的数据核对请求的数目。在具体的实施过程中,确定该数据变更消息作为上游数据时,所对应的核对规则的数目,进而根据确定的核对规则的数目,确定触发的与数据变更消息对应的数据核对请求的数目。进一步地,若确定与数据变更消息对应的上游数据对应的数据核对请求数目为1,则在从待执行队列中获取与所述数据变更消息对应的上游数据之后,将上游数据从待执行队列中删除。从而在确定待执行队列中某个上游数据所对应的所有数据核对请求被处理之后,才将该上游数据从该待执行队列中删除。
由此可见,本实施例监听来自多个数据源的数据变更消息,从而可及时获取核对数据对应的数据信息,并由预设的数据核对系统执行,避免了业务系统线上的处理压力,有利于业务系统处理效率的提升;并且本实施例并非采用现有技术中定时触发数据核对的方式,而是在当前待执行队列中不存在与数据变更消息对应的上游数据,触发与该数据变更消息对应的数据核对请求,并将数据变更消息添加至待执行队列;在确定当前待执行队列中存在与数据变更消息对应的上游数据时,从待执行队列中获取与数据变更消息对应的上游数据,并执行上游数据与数据变更消息的数据核对,及时触发上游数据与下游数据的数据核对,进而在获得的下游数据为最新的下游数据,从而降低数据核对噪音的前提下,进一步地提升了数据核对的效率;并且,本实施例根据数据变更消息对应的唯一键,能够快速准确地确定当前待执行队列中是否存在与该数据变更消息对应的上游数据,而且通过核对规则来确定唯一键的确定方式,实现存储的数据与核对规则的强联系,进一步地提升了数据核对的准确性,降低数据核对噪音;此外,本实施例在确定待执行队列中某个上游数据所对应的所有数据核对请求被处理之后,才将该上游数据从该待执行队列中删除,从而保障某一数据为多种核对规则对应的上游数据这一情形下数据核对的正常实施,提升数据核对的适用范围,适于大规模应用与实施。
图3示出了根据本发明一个实施例提供的一种基于多数据源的数据核对装置的功能结构示意图。如图3所示,该装置包括:监听模块31、确定模块32、核对模块33、及添加模块34。
监听模块31,适于监听来自多个数据源的数据变更消息;
确定模块32,适于确定当前待执行队列中是否存在与所述数据变更消息对应的上游数据;
核对模块33,适于若确定当前待执行队列中存在与所述数据变更消息对应的上游数据,则从所述待执行队列中获取与所述数据变更消息对应的上游数据,并执行所述上游数据与所述数据变更消息的数据核对;
添加模块34,适于若确定当前待执行队列中不存在与所述数据变更消息对应的上游数据,则触发与所述数据变更消息对应的数据核对请求,并将所述数据变更消息添加至所述待执行队列。
可选的,确定模块32进一步适于:
获取所述数据变更消息对应的唯一键;
根据所述数据变更消息对应的唯一键,确定当前待执行队列中是否存在与所述数据变更消息对应的上游数据。
可选的,确定模块32进一步适于:
确定与所述数据变更消息对应的核对规则;
根据所述与所述数据变更消息对应的核对规则,确定与所述数据变更消息对应的唯一键确定方式;
采用所述唯一键确定方式,确定与所述数据变更消息对应的唯一键。
可选的,所述装置还包括:异常数据处理模块(图中未示出),适于监测所述待执行队列中各数据的等待时间;
将待执行队列中等待时间超出预设阈值的数据标记为异常数据,并采用相应的异常数据处理方法,对所述异常数据进行处理。
可选的,添加模块34进一步适于:确定与所述数据变更消息对应的核对规则的数目;
根据与所述数据变更消息对应的核对规则的数目,确定触发的与所述数据变更消息对应的数据核对请求的数目。
可选的,若确定与所述数据变更消息对应的上游数据对应的数据核对请求数目为1,则在从所述待执行队列中获取与所述数据变更消息对应的上游数据之后,所述装置还包括:
删除模块(图中未示出),适于将所述上游数据从所述待执行队列中删除。
可选的,监听模块31进一步适于:确定与核对规则对应的多个数据源,针对于所述多个数据源中的每个数据源,当该数据源中发生目标数据变更时,生成与所述目标数据变更对应的数据变更消息;
订阅所述多个数据源的数据变更消息。
其中,本实施装置中各模块的具体实施过程可参照图1和/或图2所示方法实施例中相应部分的描述,本实施例在此不做赘述。
由此可见,本实施例监听来自多个数据源的数据变更消息,从而可及时获取核对数据对应的数据信息,并由预设的数据核对系统执行,避免了业务系统线上的处理压力,有利于业务系统处理效率的提升;并且本实施例并非采用现有技术中定时触发数据核对的方式,而是在当前待执行队列中不存在与数据变更消息对应的上游数据,触发与该数据变更消息对应的数据核对请求,并将数据变更消息添加至待执行队列;在确定当前待执行队列中存在与数据变更消息对应的上游数据时,从待执行队列中获取与数据变更消息对应的上游数据,并执行上游数据与数据变更消息的数据核对,及时触发上游数据与下游数据的数据核对,进而在获得的下游数据为最新的下游数据,从而降低数据核对噪音的前提下,进一步地提升了数据核对的效率。
根据本发明一个实施例提供了一种非易失性计算机存储介质,所述计算机存储介质存储有至少一可执行指令,该计算机可执行指令可执行上述任意方法实施例中的基于多数据源的数据核对方法。
图4示出了根据本发明一个实施例提供的一种计算设备的结构示意图,本发明具体实施例并不对计算设备的具体实现做限定。
如图4所示,该计算设备可以包括:处理器(processor)402、通信接口(Communications Interface)404、存储器(memory)406、以及通信总线408。
其中:
处理器402、通信接口404、以及存储器406通过通信总线408完成相互间的通信。
通信接口404,用于与其它设备比如客户端或其它服务器等的网元通信。
处理器402,用于执行程序410,具体可以执行上述基于多数据源的数据核对方法实施例中的相关步骤。
具体地,程序410可以包括程序代码,该程序代码包括计算机操作指令。
处理器402可能是中央处理器CPU,或者是特定集成电路ASIC(ApplicationSpecific Integrated Circuit),或者是被配置成实施本发明实施例的一个或多个集成电路。计算设备包括的一个或多个处理器,可以是同一类型的处理器,如一个或多个CPU;也可以是不同类型的处理器,如一个或多个CPU以及一个或多个ASIC。
存储器406,用于存放程序410。存储器406可能包含高速RAM存储器,也可能还包括非易失性存储器(non-volatile memory),例如至少一个磁盘存储器。
程序410具体可以用于使得处理器402执行以下操作:
监听来自多个数据源的数据变更消息;
确定当前待执行队列中是否存在与所述数据变更消息对应的上游数据;
若存在,则从所述待执行队列中获取与所述数据变更消息对应的上游数据,并执行所述上游数据与所述数据变更消息的数据核对;
若不存在,则触发与所述数据变更消息对应的数据核对请求,并将所述数据变更消息添加至所述待执行队列。
在一种可选的实施方式中,程序410具体可以用于使得处理器402执行以下操作:
获取所述数据变更消息对应的唯一键;
根据所述数据变更消息对应的唯一键,确定当前待执行队列中是否存在与所述数据变更消息对应的上游数据。
在一种可选的实施方式中,程序410具体可以用于使得处理器402执行以下操作:
确定与所述数据变更消息对应的核对规则;
根据所述与所述数据变更消息对应的核对规则,确定与所述数据变更消息对应的唯一键确定方式;
采用所述唯一键确定方式,确定与所述数据变更消息对应的唯一键。
在一种可选的实施方式中,程序410具体可以用于使得处理器402执行以下操作:
监测所述待执行队列中各数据的等待时间;
将待执行队列中等待时间超出预设阈值的数据标记为异常数据,并采用相应的异常数据处理方法,对所述异常数据进行处理。
在一种可选的实施方式中,程序410具体可以用于使得处理器402执行以下操作:
确定与所述数据变更消息对应的核对规则的数目;
根据与所述数据变更消息对应的核对规则的数目,确定触发的与所述数据变更消息对应的数据核对请求的数目。
在一种可选的实施方式中,程序410具体可以用于使得处理器402执行以下操作:
若确定与所述数据变更消息对应的上游数据对应的数据核对请求数目为1,则在从所述待执行队列中获取与所述数据变更消息对应的上游数据之后,
将所述上游数据从所述待执行队列中删除。
在一种可选的实施方式中,程序410具体可以用于使得处理器402执行以下操作:
确定与核对规则对应的多个数据源,针对于所述多个数据源中的每个数据源,当该数据源中发生目标数据变更时,生成与所述目标数据变更对应的数据变更消息;
订阅所述多个数据源的数据变更消息。
在此提供的算法和显示不与任何特定计算机、虚拟系统或者其它设备固有相关。各种通用系统也可以与基于在此的示教一起使用。根据上面的描述,构造这类系统所要求的结构是显而易见的。此外,本发明也不针对任何特定编程语言。应当明白,可以利用各种编程语言实现在此描述的本发明的内容,并且上面对特定语言所做的描述是为了披露本发明的最佳实施方式。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
类似地,应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多的特征。更确切地说,如下面的权利要求书所反映的那样,发明方面在于少于前面公开的单个实施例的所有特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组件组合成一个模块或单元或组件,以及此外可以把它们分成多个子模块或子单元或子组件。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。
本发明的各个部件实施例可以以硬件实现,或者以在一个或者多个处理器上运行的软件模块实现,或者以它们的组合实现。本领域的技术人员应当理解,可以在实践中使用微处理器或者数字信号处理器(DSP)来实现根据本发明实施例的基于多数据源的数据核对装置中的一些或者全部部件的一些或者全部功能。本发明还可以实现为用于执行这里所描述的方法的一部分或者全部的设备或者装置程序(例如,计算机程序和计算机程序产品)。这样的实现本发明的程序可以存储在计算机可读介质上,或者可以具有一个或者多个信号的形式。这样的信号可以从因特网网站上下载得到,或者在载体信号上提供,或者以任何其他形式提供。
应该注意的是上述实施例对本发明进行说明而不是对本发明进行限制,并且本领域技术人员在不脱离所附权利要求的范围的情况下可设计出替换实施例。在权利要求中,不应将位于括号之间的任何参考符号构造成对权利要求的限制。单词“包含”不排除存在未列在权利要求中的元件或步骤。位于元件之前的单词“一”或“一个”不排除存在多个这样的元件。本发明可以借助于包括有若干不同元件的硬件以及借助于适当编程的计算机来实现。在列举了若干装置的单元权利要求中,这些装置中的若干个可以是通过同一个硬件项来具体体现。单词第一、第二、以及第三等的使用不表示任何顺序。可将这些单词解释为名称。

Claims (16)

1.一种基于多数据源的数据核对方法,包括:
监听来自多个数据源的数据变更消息;
确定当前待执行队列中是否存在与所述数据变更消息对应的上游数据;
若存在,则从所述待执行队列中获取与所述数据变更消息对应的上游数据,并执行所述上游数据与所述数据变更消息的数据核对;
若不存在,则触发与所述数据变更消息对应的数据核对请求,并将所述数据变更消息添加至所述待执行队列。
2.根据权利要求1所述的方法,其中,所述确定当前待执行队列中是否存在与所述数据变更消息对应的上游数据进一步包括:
获取所述数据变更消息对应的唯一键;
根据所述数据变更消息对应的唯一键,确定当前待执行队列中是否存在与所述数据变更消息对应的上游数据。
3.根据权利要求2所述的方法,其中,所述获取所述数据变更消息对应的唯一键进一步包括:
确定与所述数据变更消息对应的核对规则;
根据所述与所述数据变更消息对应的核对规则,确定与所述数据变更消息对应的唯一键确定方式;
采用所述唯一键确定方式,确定与所述数据变更消息对应的唯一键。
4.根据权利要求1-3中任一项所述的方法,其中,所述方法还包括:
监测所述待执行队列中各数据的等待时间;
将待执行队列中等待时间超出预设阈值的数据标记为异常数据,并采用相应的异常数据处理方法,对所述异常数据进行处理。
5.根据权利要求1-3中任一项所述的方法,其中,所述触发与所述数据变更消息对应的数据核对请求,并将所述数据变更消息添加至所述待执行队列进一步包括:
确定与所述数据变更消息对应的核对规则的数目;
根据与所述数据变更消息对应的核对规则的数目,确定触发的与所述数据变更消息对应的数据核对请求的数目。
6.根据权利要求5所述的方法,其中,若确定与所述数据变更消息对应的上游数据对应的数据核对请求数目为1,则在从所述待执行队列中获取与所述数据变更消息对应的上游数据之后,所述方法还包括:
将所述上游数据从所述待执行队列中删除。
7.根据权利要求1-3中任一项所述的方法,其中,所述监听来自多个数据源的数据变更消息进一步包括:
确定与核对规则对应的多个数据源,针对于所述多个数据源中的每个数据源,当该数据源中发生目标数据变更时,生成与所述目标数据变更对应的数据变更消息;
订阅所述多个数据源的数据变更消息。
8.一种基于多数据源的数据核对装置,包括:
监听模块,适于监听来自多个数据源的数据变更消息;
确定模块,适于确定当前待执行队列中是否存在与所述数据变更消息对应的上游数据;
核对模块,适于若确定当前待执行队列中存在与所述数据变更消息对应的上游数据,则从所述待执行队列中获取与所述数据变更消息对应的上游数据,并执行所述上游数据与所述数据变更消息的数据核对;
添加模块,适于若确定当前待执行队列中不存在与所述数据变更消息对应的上游数据,则触发与所述数据变更消息对应的数据核对请求,并将所述数据变更消息添加至所述待执行队列。
9.根据权利要求8所述的装置,其中,所述确定模块进一步适于:
获取所述数据变更消息对应的唯一键;
根据所述数据变更消息对应的唯一键,确定当前待执行队列中是否存在与所述数据变更消息对应的上游数据。
10.根据权利要求9所述的装置,其中,所述确定模块进一步适于:
确定与所述数据变更消息对应的核对规则;
根据所述与所述数据变更消息对应的核对规则,确定与所述数据变更消息对应的唯一键确定方式;
采用所述唯一键确定方式,确定与所述数据变更消息对应的唯一键。
11.根据权利要求8-10中任一项所述的装置,其中,所述装置还包括:
异常数据处理模块,适于监测所述待执行队列中各数据的等待时间;
将待执行队列中等待时间超出预设阈值的数据标记为异常数据,并采用相应的异常数据处理方法,对所述异常数据进行处理。
12.根据权利要求8-10中任一项所述的装置,其中,所述添加模块进一步适于:确定与所述数据变更消息对应的核对规则的数目;
根据与所述数据变更消息对应的核对规则的数目,确定触发的与所述数据变更消息对应的数据核对请求的数目。
13.根据权利要求12所述的装置,其中,若确定与所述数据变更消息对应的上游数据对应的数据核对请求数目为1,则在从所述待执行队列中获取与所述数据变更消息对应的上游数据之后,所述装置还包括:
删除模块,适于将所述上游数据从所述待执行队列中删除。
14.根据权利要求8-10中任一项所述的装置,其中,所述监听模块进一步适于:确定与核对规则对应的多个数据源,针对于所述多个数据源中的每个数据源,当该数据源中发生目标数据变更时,生成与所述目标数据变更对应的数据变更消息;
订阅所述多个数据源的数据变更消息。
15.一种计算设备,包括:处理器、存储器、通信接口和通信总线,所述处理器、所述存储器和所述通信接口通过所述通信总线完成相互间的通信;
所述存储器用于存放至少一可执行指令,所述可执行指令使所述处理器执行如权利要求1-7中任一项所述的基于多数据源的数据核对方法对应的操作。
16.一种计算机存储介质,所述存储介质中存储有至少一可执行指令,所述可执行指令使处理器执行如权利要求1-7中任一项所述的基于多数据源的数据核对方法对应的操作。
CN201910465750.9A 2019-05-30 2019-05-30 基于多数据源的数据核对方法及装置 Expired - Fee Related CN110209512B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201910465750.9A CN110209512B (zh) 2019-05-30 2019-05-30 基于多数据源的数据核对方法及装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201910465750.9A CN110209512B (zh) 2019-05-30 2019-05-30 基于多数据源的数据核对方法及装置

Publications (2)

Publication Number Publication Date
CN110209512A CN110209512A (zh) 2019-09-06
CN110209512B true CN110209512B (zh) 2020-06-30

Family

ID=67789752

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201910465750.9A Expired - Fee Related CN110209512B (zh) 2019-05-30 2019-05-30 基于多数据源的数据核对方法及装置

Country Status (1)

Country Link
CN (1) CN110209512B (zh)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114201484A (zh) * 2021-12-16 2022-03-18 北京达佳互联信息技术有限公司 信息处理方法、装置、电子设备及存储介质

Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102226898A (zh) * 2011-06-13 2011-10-26 中国有色金属长沙勘察设计研究院有限公司 在线监测系统中控制监测数据入库的方法和装置
CN102662946A (zh) * 2012-02-20 2012-09-12 北京地拓科技发展有限公司 一种自动监测数据库中记录变化的方法和系统
CN104461613A (zh) * 2014-11-14 2015-03-25 北京百度网讯科技有限公司 对应用程序的浮窗信息展示进行管理的方法及装置
CN107239930A (zh) * 2017-05-15 2017-10-10 太仓诚泽网络科技有限公司 一种基于数据处理的企业管理系统
CN108074028A (zh) * 2016-11-16 2018-05-25 上海成括信息科技有限公司 增加净资本风险监控系统准确性的方法及产品
CN109254990A (zh) * 2018-09-11 2019-01-22 北京唐冠天朗科技开发有限公司 一种信息源采集和动态分析的方法和系统
CN109299150A (zh) * 2018-10-24 2019-02-01 万惠投资管理有限公司 一种可配置多数据源适配规则引擎解决方法

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101163036B (zh) * 2006-10-10 2011-08-10 中兴通讯股份有限公司 实现网络设备管理软件双机热备份的方法
CN103136276A (zh) * 2011-12-02 2013-06-05 阿里巴巴集团控股有限公司 一种数据核对系统,方法及装置
CN104283318B (zh) * 2014-10-24 2016-03-23 国家电网公司 基于大数据的电力设备综合监测与预警系统及其分析方法
CN107766572A (zh) * 2017-11-13 2018-03-06 北京国信宏数科技有限责任公司 基于经济领域数据的分布式提取及可视化分析方法和系统

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102226898A (zh) * 2011-06-13 2011-10-26 中国有色金属长沙勘察设计研究院有限公司 在线监测系统中控制监测数据入库的方法和装置
CN102662946A (zh) * 2012-02-20 2012-09-12 北京地拓科技发展有限公司 一种自动监测数据库中记录变化的方法和系统
CN104461613A (zh) * 2014-11-14 2015-03-25 北京百度网讯科技有限公司 对应用程序的浮窗信息展示进行管理的方法及装置
CN108074028A (zh) * 2016-11-16 2018-05-25 上海成括信息科技有限公司 增加净资本风险监控系统准确性的方法及产品
CN107239930A (zh) * 2017-05-15 2017-10-10 太仓诚泽网络科技有限公司 一种基于数据处理的企业管理系统
CN109254990A (zh) * 2018-09-11 2019-01-22 北京唐冠天朗科技开发有限公司 一种信息源采集和动态分析的方法和系统
CN109299150A (zh) * 2018-10-24 2019-02-01 万惠投资管理有限公司 一种可配置多数据源适配规则引擎解决方法

Also Published As

Publication number Publication date
CN110209512A (zh) 2019-09-06

Similar Documents

Publication Publication Date Title
CN109104336B (zh) 服务请求处理方法、装置、计算机设备及存储介质
CN107633016B (zh) 数据处理方法及装置和电子设备
CN107872528B (zh) 消息推送方法及装置
CN107038182B (zh) 分表数据的完备性检查方法及装置
CN111756644B (zh) 热点限流方法、系统、设备及存储介质
CN111679968A (zh) 接口调用异常的检测方法、装置、计算机设备及存储介质
CN110581887A (zh) 数据处理方法、装置、区块链节点及存储介质
CN108509322B (zh) 避免过度回访的方法、电子装置及计算机可读存储介质
CN112835885B (zh) 一种分布式表格存储的处理方法、装置及系统
CN110209512B (zh) 基于多数据源的数据核对方法及装置
CN110175182B (zh) 数据核对方法及装置
CN107329832B (zh) 一种数据接收方法及装置
CN113486109A (zh) 异构数据库的数据同步方法、装置及电子设备
US11243979B1 (en) Asynchronous propagation of database events
CN108062224B (zh) 基于文件句柄的数据读写方法、装置及计算设备
CN111222783A (zh) 处理工作流的方法及电子设备
CN110362464B (zh) 软件分析方法及设备
CN113961632A (zh) 消息数据处理方法、装置及电子设备
CN111459789B (zh) 一种应用程序编程接口的检测方法及装置
CN113297149A (zh) 数据处理请求的监测方法及装置
CN113505017A (zh) 一种问题排查方法、装置、存储介质和设备
CN111488236A (zh) 一种订单异常处理方法、服务器、存储介质及处理装置
CN114520808A (zh) 请求处理方法、装置、电子设备及计算机可读存储介质
CN115952172B (zh) 一种基于数据库临时表的数据匹配方法及装置
CN111639085B (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
GR01 Patent grant
GR01 Patent grant
CF01 Termination of patent right due to non-payment of annual fee

Granted publication date: 20200630