CN110597907B - 跨区块链的数据信息同步方法、装置、设备及介质 - Google Patents
跨区块链的数据信息同步方法、装置、设备及介质 Download PDFInfo
- Publication number
- CN110597907B CN110597907B CN201910854471.1A CN201910854471A CN110597907B CN 110597907 B CN110597907 B CN 110597907B CN 201910854471 A CN201910854471 A CN 201910854471A CN 110597907 B CN110597907 B CN 110597907B
- Authority
- CN
- China
- Prior art keywords
- block
- chain
- cross
- header information
- transaction data
- 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
Links
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/27—Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor
- G06F16/275—Synchronous replication
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/38—Payment protocols; Details thereof
- G06Q20/382—Payment protocols; Details thereof insuring higher security of transaction
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/38—Payment protocols; Details thereof
- G06Q20/389—Keeping log of transactions for guaranteeing non-repudiation of a transaction
Landscapes
- Engineering & Computer Science (AREA)
- Business, Economics & Management (AREA)
- Accounting & Taxation (AREA)
- Theoretical Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- Databases & Information Systems (AREA)
- Finance (AREA)
- Strategic Management (AREA)
- General Business, Economics & Management (AREA)
- General Engineering & Computer Science (AREA)
- Data Mining & Analysis (AREA)
- Computing Systems (AREA)
- Computer Security & Cryptography (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本发明公开了一种跨区块链的数据信息同步方法、装置、设备及介质,属于网络技术领域,本发明实施例提供的技术方案,提供了一种简单的跨区块链的数据同步方法,通过在区块链上有新区块生成时能够同步至不属于区块链的网络设备,从而可以由该网络设备来作为中转设备,这种网络设备不参与共识,仅作为链与链之间状态数据的搬运工和监测跨链交易事件,在该网络设备通过新生成的区块检测到区块链之间发生了跨链交易时,则可以将区块内的跨链交易数据通过链下同步的方式同步至交易所涉及的区块链,以完成跨链交易,在保证交易真实可靠的同时,整个流程大大简化了对跨链交易进行处理时的复杂度。
Description
技术领域
本发明涉及网络技术领域,特别涉及一种跨区块链的数据信息同步方法、装置、设备及介质。
背景技术
随着网络技术的发展,为了保证数据的安全可靠性,区块链技术越来越广泛的应用于各个领域,区块链是指一串使用密码学方法相关联产生的区块,在生成区块时,需要基于上一个区块中的数据和当前交易信息生成,这样便使得区块链中每个区块中的数据均与上一个区块中的数据存在关联,因此,无法通过篡改区块上的数据来进行作弊,能够确保根据区块上的任何数据均是公开透明的,提高了交易信息的安全性。
然而,随着数据共享的需求的演进,目前已有的区块链虽然能够在配置有同一区块链的节点设备之间实现数据信息的同步,而对于不同区块链之间也即是跨区块链的数据信息同步,还处于技术的空白,亟需提出一种有效的解决方案。
发明内容
本发明实施例提供了一种跨区块链的数据信息同步方法、装置、设备及介质,提供了一种兼具真实性和流程简化等特点的跨链交易实现方法。所述技术方案如下:
一方面,提供了一种跨区块链的数据信息同步方法,包括:
获取第一区块链系统第一区块头信息,所述第一区块头信息用于指示第一区块链上新生成的第一区块;
当基于所述第一区块头信息确定所述第一区块包括所述第一区块链与第二区块链之间的跨链交易数据时,根据存储有所述第一区块链的区块头信息的第一数据库,对所述第一区块头信息进行校验;
当校验通过时,基于所述第一区块头信息,从所述第一区块中获取跨链交易数据;
将所述跨链交易数据发送至第二区块链系统,由所述第二区块链系统在所述跨链交易数据校验通过后基于所述跨链交易数据执行跨链交易。
一方面,提供了一种跨区块链的数据信息同步方法,应用于第一区块链上的任一个节点设备,所述方法包括:
对第一区块链进行检测;
当检测到所述第一区块链上新增任一区块时,如果所述区块为第一区块,则获取所述第一区块的第一区块头信息,所述第一区块包括所述第一区块链与第二区块链之间的跨链交易数据;
向目标网络设备发送第一区块头信息,所述第一区块头信息用于指示所述第一区块链上新生成的所述第一区块。
一方面,提供了一种跨区块链的数据信息同步装置,所述装置包括:
接收模块,用于获取第一区块链系统的第一区块头信息,所述第一区块头信息用于指示第一区块链上新生成的第一区块;
校验模块,用于当基于所述第一区块头信息确定所述第一区块包括所述第一区块链与第二区块链之间的跨链交易数据时,根据存储有所述第一区块链的区块头信息的第一数据库,对所述第一区块头信息进行校验;
获取模块,用于当校验通过时,基于所述第一区块头信息,从所述第一区块中获取跨链交易数据;
发送模块,用于将所述跨链交易数据发送至第二区块链系统,由所述第二区块链系统在所述跨链交易数据校验通过后基于所述跨链交易数据执行跨链交易。
在一种可能实现方式中,所述装置还包括检测模块,用于从所述第一区块头信息中提取梅克尔树,对所述梅克尔树进行检测,当所述梅克尔树中的任一梅克尔值指示不同区块链之间的交易数据时,则确定所述第一区块中包括所述第一区块链与第二区块链之间的跨链交易数据。
在一种可能实现方式中,所述装置还包括记录模块,用于当校验未通过时,基于所述第一区块链系统中发起所述跨链交易的节点设备的节点标识,生成所述节点设备的交易可疑事件记录。
在一种可能实现方式中,所述跨链交易数据中包括所述第一区块链的链标识、所述第二区块链的链标识、跨链交易在所述第一区块链和所述第二区块链上的合约地址以及跨链交易操作指示信息。
在一种可能实现方式中,所述发送模块还用于当接收到所述第二区块链系统的跨链交易结果时,将所述跨链交易结果发送至所述第一区块链系统,由所述第一区块链系统验证通过后进行存储。
在一种可能实现方式中,所述发送模块还用于向所述第一区块链发送跨链交易提交证明,所述跨链交易提交证明用于指示已经将所述跨链交易提交给所述第二区块链。
一方面,提供了一种跨区块链的数据信息同步装置,所述装置包括:
检测模块,用于对第一区块链进行检测;
获取模块,用于当检测到所述第一区块链上新增任一区块时,如果所述区块为第一区块,则获取所述第一区块的第一区块头信息,所述第一区块包括所述第一区块链与第二区块链之间的跨链交易数据;
发送模块,用于向目标网络设备发送第一区块头信息,所述第一区块头信息用于指示所述第一区块链上新生成的所述第一区块。
在一种可能实现方式中,该装置还包括处理模块,用于当接收到所述目标网络设备发送的跨链交易数据时,根据所述跨链交易数据执行跨链交易,将跨链交易结果通过所述目标网络设备发送至所述第二区跨链系统。
一方面,提供了一种网络设备,所述网络设备包括处理器和存储器,所述存储器中存储有至少一条程序代码,所述程序代码由所述处理器加载并执行以实现上述所述的跨区块链的数据信息同步所执行的操作。
一方面,提供了一种计算机可读存储介质,所述存储介质中存储有至少一条指令,所述指令由处理器加载并执行以实现上述所述的跨区块链的数据信息同步所执行的操作。
本发明实施例提供的技术方案,提供了一种简单的跨区块链的数据同步方法,通过在区块链上有新区块生成时能够同步至不属于区块链的网络设备,从而可以由该网络设备来作为中转设备,在该网络设备通过新生成的区块检测到区块链之间发生了跨链交易时,则可以将区块内的跨链交易数据通过链下同步的方式同步至交易所涉及的区块链,以完成跨链交易,在保证交易真实可靠的同时,整个流程大大简化了对跨链交易进行处理时的复杂度。
附图说明
为了更清楚地说明本发明实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本发明实施例提供的一种跨区块链的数据信息同步方法的实施环境结构图;
图2是本发明实施例提供的一种跨区块链的数据信息同步方法的流程图;
图3是本发明实施例提供的一种跨区块链的数据信息同步装置的结构示意图;
图4是本发明实施例提供的一种跨区块链的数据信息同步装置的结构示意图;
图5是本发明实施例提供的一种网络设备500的示意图。
具体实施方式
为使本发明的目的、技术方案和优点更加清楚,下面将结合附图对本发明实施方式作进一步地详细描述。
下面,对下述具体说明过程中出现的一些名词进行介绍:
智能合约:根据特定条件自动执行的合约程序,是用户与区块链进行交互,利用区块链实现业务逻辑的重要途径。在本发明实施例中,该智能合约可以具体表现为跨链交易智能合约,也即是,可以基于跨链交易数据触发该跨链交易智能合约来执行具体的跨链交易,例如,以银行转账为例,当在A银行中进行一笔向B银行的转账交易,如果A银行和B银行分别属于不同的区块链联盟,则该笔转账交易可以基于联盟之间所约定的交易处理方式来进行处理,具体的交易处理方式可以通过跨链交易智能合约的方式存储在上述A银行和B银行的区块链上,以便基于跨链交易请求来执行具体的跨链交易。
图1是本发明实施例提供的一种跨区块链的数据信息同步方法的实施环境结构图。该实施环境包括多个网络设备101以及至少两条区块链系统的多个节点设备102,该多个网络设备101为多家机构的服务器。网络设备101可以属于任一家由区块链系统信任的机构,例如区块链服务提供商、银行、金融机构、信贷机构、征信机构或消费机构等等,该多个网络设备101可以为多条区块链服务,但是,该多个网络设备101不参与区块链的共识,也即是,该多个网络设备101为链外设备。该至少两条区块链系统所配置的区块链为不同的区块链,例如,该至少两条区块链可以为不同的联盟链或公有链等,本发明实施例对区块链的类型不做限定。
图2是本发明实施例提供的一种跨区块链的数据信息同步方法的流程图。该方法可以应用于如图1所提供的实施环境中。参见图2,该方法包括:
201、第一区块链系统对第一区块链进行检测。
对于第一区块链系统中的任一个节点设备来说,可以对第一区块链系统所配置的第一区块链进行检测,以获知是否有新区块生成,例如,检测是否接收到新区块,或者,检测是否生成了新区块等,本发明实施例对其具体检测过程不做限定。
202、当检测到该第一区块链上新增第一区块时,则第一区块链系统获取该第一区块的第一区块头信息,该第一区块包括该第一区块链与第二区块链之间的跨链交易数据。
在该过程中,当检测到第一区块链上新增任一个区块时,第一区块链系统中的节点设备可以获取该区块的区块头信息,判断该区块头信息是否能够指示区块中包括该第一区块链与第二区块链之间的跨链交易数据,从而确定该区块是否为第一区块。其中,判断该区块头信息是否能够指示区块中包括该第一区块链与第二区块链之间的跨链交易数据的过程包括:从该区块头信息中提取梅克尔树,对该梅克尔树进行检测,当该梅克尔树中的任一梅克尔值指示不同区块链之间的交易数据时,则确定该区块头信息用于指示区块中包括该第一区块链与第二区块链之间的跨链交易数据,也即是,该区块为第一区块。
其中,梅克尔树是指merkle树,其是区块链技术中一种用于对数据进行验证的结构,节点设备在生成区块的过程中会基于待打包的交易数据来生成merkle树,并会将梅克尔树存储至区块头信息中,因此,梅克尔树可以用于指示区块具体包含了哪些交易数据。
203、第一区块链系统向第一网络设备发送第一区块头信息,该第一区块头信息用于指示该第一区块链上新生成的该第一区块。
在本发明实施例中,仅以第一区块链系统和第二区块链系统通过第一网络设备来进行数据同步为例进行说明,而在一些可能实现方式中,该实施环境中可以包括多个网络设备,用以进行数据同步,而第一区块链系统和第二区块链系统可以从多个网络设备中选择一个网络设备来作为本次数据同步所使用的网络设备,该选择方式可以包括多种,例如,可以基于网络状态,选择当前网络速度最快的网络设备,又或者,可以基于各个网络设备的历史同步过程中的同步成功率,选择同步成功率满足目标条件的网络设备,其中,该同步成功率可以基于网络设备向区块链系统发送的提交证明以及后续区块链系统是否跨链交易成功来确定,本发明实施例在此不做赘述。
204、第一网络设备接收第一区块链系统的第一区块头信息,该第一区块头信息用于指示该第一区块链上新生成的第一区块。
需要说明的是,上述步骤201-204是由区块链系统主动基于区块链上的区块变化来向网络设备进行新区块生成的通知为例进行说明,在一种可能实现方式中,还可以由网络设备来主动的监测区块链上区块的生成,在监测到生成了第一区块时,由网络设备主动获取该第一区块的第一区块头信息,以进行后续的数据同步流程,例如,第一网络设备可以周期性检测区块链系统的区块链上对否有新区块生成,本发明实施例对采用哪种形式来获取第一区块头信息不做限定。
205、第一网络设备从该第一区块头信息中提取梅克尔树,对该梅克尔树进行检测,当该梅克尔树中的任一梅克尔值指示不同区块链之间的交易数据时,则确定该第一区块中包括该第一区块链与第二区块链之间的跨链交易数据。
网络设备在获取到新区块的区块头信息,可以判断该区块头信息是否能够指示区块中包括该第一区块链与第二区块链之间的跨链交易数据,从而确定该区块是否为第一区块。其中,判断该区块头信息是否能够指示区块中包括该第一区块链与第二区块链之间的跨链交易数据的过程包括:从该区块头信息中提取梅克尔树,对该梅克尔树进行检测,当该梅克尔树中的任一梅克尔值指示不同区块链之间的交易数据时,则确定该区块头信息用于指示区块中包括该第一区块链与第二区块链之间的跨链交易数据,也即是,该区块为第一区块。
第一网络设备可以在接收到第一区块链系统的第一区块头信息后,根据存储有该第一区块链的区块头信息的第一数据库,对该第一区块头信息进行校验,来确定其合法性。如果校验未通过时,第一网络设备基于该第一区块链系统中发起该跨链交易的节点设备的节点标识,生成该节点设备的交易可疑事件记录,通过对交易可疑事件进行记录,可以对发起交易的节点设备做出警告提示,为后续的惩罚处理准备,并结束本轮同步流程,当校验通过时,第一网络设备将该第一区块头信息存储至该第一数据库。
需要说明的是,对于任一个网络设备来说,当其所接收到的区块头信息校验通过后,均需将该区块头信息存储至与区块链系统对应的数据库中,各个网络设备可以为不同区块链系统维护对应的数据库,以便在后续基于该数据库中所存储的区块头信息对新接收到的区块头信息进行校验。
在本发明实施例中,对于跨链交易来说,区块链上的节点设备可以为其生成跨链交易梅克尔树,用于单独维护跨链交易,以使网络设备能够更快的检测到跨链交易。
206、当基于该第一区块头信息确定该第一区块包括该第一区块链与第二区块链之间的跨链交易数据时,第一网络设备基于该第一区块头信息,从该第一区块中获取跨链交易数据。
对于第一网络设备来说,可以在检测到有跨链交易发生时,向发起跨链交易的区块链发起数据同步,来获取第一区块头所指示的跨链交易数据,该跨链交易数据可以包括跨链交易ID、跨链交易的源区块链标识、目标区块链标识、跨链交易在上述链上的合约地址以及跨链交易操作方法等,以便进行进一步的数据同步。例如,在本发明实施例中,该跨链交易数据中包括该第一区块链的链标识、该第二区块链的链标识、跨链交易在该第一区块链和该第二区块链上的合约地址以及跨链交易操作指示信息。
207、第一网络设备将该跨链交易数据发送至第二区块链系统。
第一网络设备在获取到跨链交易数据后,可以根据跨链交易数据中的目标区块链标识,确定目标区块链,从而将跨链交易数据发送至目标区块链系统,以便执行跨链交易。
需要说明的是,对于网络设备来说,其可以存储有多个区块链系统的区块链标识以及对应的地址,从而能够在确定发送对象时,获取对应地址进行发送。
另外,在第一网络设备将跨链交易数据发送至第二区块链系统时,还可以将第一区块头信息发送至第二区块链系统,以实现区块头信息的同步,对于这两种数据可以同时发送也可以具有一定先后顺序的发送,本发明实施例对此不做限定,而当第二区块链系统接收到该第一区块头信息后,也可以进行校验,并在校验通过后将其存储在第二区块链上。
208、该第二区块链系统在该跨链交易数据校验通过后,基于该跨链交易数据执行跨链交易。
需要说明的是,对于第二区块链系统来说,也需要对跨链交易数据进行校验,以验证链与链之间跨链交易的合法性,目标区块链可以根据自身链上所存储的数据和跨链交易数据,来校验交易的合法性以及交易双方的作恶情况。
209、当跨链交易完成后,该第二区块链系统向该第一网络设备发送跨链交易结果。
210、当接收到该第二区块链系统的跨链交易结果时,第一网络设备将该跨链交易结果发送至该第一区块链系统,由该第一区块链系统验证通过后进行存储。
在上述步骤208至步骤210中,当第二区块链系统校验通过后,则可以运行预先部署的跨链交易合约来执行跨链交易,将交易结果返回给第一网络设备,该第一网络设备将交易结果转发给第一区跨链系统。
需要说明的是,在跨链交易数据同步执行的过程中,跨链交易发起链也即是本发明实施例中的第一区块链系统可以给予第一网络设备一定的激励。
为了防止Hub在同步跨链交易作恶情况,源区块链和网络设备之间可以通过进一步的验证方式来保证交易合法性,也即是,在一种可能实现方式中,该第一网络设备在发送了跨链交易数据后,还可以向该第一区块链发送跨链交易提交证明Submit Proof,,该跨链交易提交证明用于指示已经将该跨链交易提交给该第二区块链系统,从而使得第一区块链对第一网络设备的发送行为进行确认,来完成发送的闭环。而对于第一区块链来说,可以根据跨链交易提交证明校验第一网络设备反馈的上述跨链交易结果合法性,如果非法,将第一网络设备加入黑名单并告警提示。当然,为了避免错误处理,还可以给出申述空窗期,给第一网络设备提出证明申述的机会。
上述步骤209至211是第二区块链系统根据所述跨链交易数据执行跨链交易,将跨链交易结果通过所述目标网络设备发送至所述第二区跨链系统的过程。
在上述过程中,仅以第一区块链系统作为跨链交易的源区块链系统,第二区块链系统作为目标区块链系统为例进行说明,而在任一种可能实现方式中,任一区跨链系统均可以作为源区块链系统来进行交易的发起,本发明实施例对此不做限定。
而上述实施例中也仅以第一网络设备作为中转设备为例进行说明,而在一些可能实现方式中,整个实施环境中可以有多个网络设备,该多个网络设备可以并行对区块链系统进行监测,而对于区块链系统来说,为了防止多个网络设备提交同一个跨链交易数据,可以采取先到先得原则,仅处理最早收到的跨链交易数据,而忽略之后到达的同一份跨链交易数据。
本发明实施例提供的技术方案,提供了一种简单的跨区块链的数据同步方法,通过在区块链上有新区块生成时能够同步至不属于区块链的网络设备,从而可以由该网络设备来作为中转设备,这种网络设备不参与共识,仅作为链与链之间状态数据的搬运工和监测跨链交易事件,在该网络设备通过新生成的区块检测到区块链之间发生了跨链交易时,则可以将区块内的跨链交易数据通过链下同步的方式同步至交易所涉及的区块链,以完成跨链交易,在保证交易真实可靠的同时,整个流程大大简化了对跨链交易进行处理时的复杂度。进一步地,任何节点设备都可以参与数据中转来,只需要部署了对应的区块链数据状态同步程序,大大降低了对数据中转的要求。
图3是本发明实施例提供的一种跨区块链的数据信息同步装置的结构示意图。参见图3,该装置包括:
接收模块301,用于接收第一区块链的第一区块头信息,所述第一区块头信息用于指示所述第一区块链上新生成的区块;
校验模块302,用于当确定所述第一区块头信息对应于所述第一区块链与所述第二区块链之间的跨链交易时,对所述第一区块头信息进行校验;
获取模块303,用于当校验通过时,基于所述第一区块头信息,从所述第一区块链中的第一区块中获取跨链交易数据,所述第一区块包括所述第一区块头信息;
发送模块304,用于将所述跨链交易数据发送至所述第二区块链,由所述第二区块链在对所述跨链交易数据校验通过时执行所述跨链交易。
在一种可能实现方式中,该校验模块用于根据第一数据库中已存储的区块头信息,对所述第一区块头信息进行合法性校验,所述第一数据库用于存储所述第一区块链中区块的区块头信息。
在一种可能实现方式中,所述装置还包括:检测模块,用于从所述第一区块头信息中提取梅克尔树,对所述梅克尔树进行检测,当所述梅克尔树中的任一梅克尔值为不同区块链之间的交易数据时,则确定所述第一区块头信息对应于跨链交易。
在一种可能实现方式中,所述装置还包括:记录生成模块,用于当校验未通过时,对所述第一区块链中发起所述跨链交易的节点设备进行记录,生成所述节点设备的交易可疑事件记录。
在一种可能实现方式中,所述跨链交易数据中包括所述第一区块链的链标识、所述第二区块链的链标识、跨链交易在所述第一区块链和所述第二区块链上的合约地址以及跨链交易操作指示信息。
在一种可能实现方式中,该发送模块还用于当接收到所述第二区块链的跨链交易结果时,将所述跨链交易结果发送至所述第一区块链。
在一种可能实现方式中,该发送模块还用于向所述第一区块链发送跨链交易提交证明,所述跨链交易提交证明用于指示已经将所述跨链交易提交给所述第二区块链。
上述所有可选技术方案,可以采用任意结合形成本公开的可选实施例,在此不再一一赘述。
图4是本发明实施例提供的一种数据处理装置的结构示意图。参见图4,该装置包括:
检测模块401,用于对所述第一区块链进行检测;
所述获取模块401还用于当检测到所述第一区块链上有第一区块生成时,获取所述第一区块的第一区块头信息;
发送模块402,用于向目标网络设备发送第一区块头信息,所述第一区块头信息用于指示所述第一区块链上新生成的第一区块。
在一种可能实现方式中,该发送模块还用于当接收到所述目标网络设备发送的跨链交易数据时,根据所述跨链交易数据执行跨链交易,将跨链交易结果通过所述目标网络设备发送至发起所述跨链交易的区跨链。
上述所有可选技术方案,可以采用任意结合形成本公开的可选实施例,在此不再一一赘述。
图5是本发明实施例提供的一种网络设备500的示意图,该网络设备500可因配置或性能不同而产生比较大的差异,可以包括一个或一个以上处理器(central processingunits,CPU)501和一个或一个以上的存储器502,其中,所述存储器502中存储有至少一条指令,所述至少一条指令由所述处理器501加载并执行以实现上述各个方法实施例提供的跨区块链的数据信息同步方法。当然,该网络设备还可以具有有线或无线网络接口、键盘以及输入输出接口等部件,以便进行输入输出,该网络设备还可以包括其他用于实现设备功能的部件,在此不做赘述。
在示例性实施例中,还提供了一种计算机可读存储介质,例如包括指令的存储器,上述指令可由终端中的处理器执行以完成上述实施例中的跨区块链的数据信息同步方法。例如,所述计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
本领域普通技术人员可以理解实现上述实施例的全部或部分步骤可以通过硬件来完成,也可以通过程序来指令相关的硬件完成,所述的程序可以存储于一种计算机可读存储介质中,上述提到的存储介质可以是只读存储器,磁盘或光盘等。
以上所述仅为本发明的较佳实施例,并不用以限制本发明,凡在本发明的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。
Claims (12)
1.一种跨区块链的数据信息同步方法,其特征在于,应用于不属于第一区块链系统和第二区块链系统的网络设备上,所述网络设备为所述第一区块链系统从设置的多个网络设备中选取的当前网络速度最快的网络设备,或者同步成功率满足目标条件的网络设备,所述多个网络设备属于任一家由所述第一区块链系统和所述第二区块链系统信任的机构,包括:
获取第一区块链系统的第一区块头信息,所述第一区块头信息用于指示第一区块链上新生成的第一区块,所述第一区块头信息是由所述第一区块链系统中的任一个节点设备发送的,其中,所述任一节点设备用于对所述第一区块链进行检测,当检测到所述第一区块链上新增任一区块时,如果所述区块为所述第一区块,则获取所述第一区块的第一区块头信息,向所述网络设备发送所述第一区块头信息;
当基于所述第一区块头信息确定所述第一区块包括所述第一区块链与第二区块链之间的跨链交易数据时,根据存储有所述第一区块链的区块头信息的第一数据库,对所述第一区块头信息进行校验;
当校验通过时,基于所述第一区块头信息,从所述第一区块中获取跨链交易数据;
将所述跨链交易数据发送至第二区块链系统,由所述第二区块链系统在所述跨链交易数据校验通过后基于所述跨链交易数据执行跨链交易。
2.根据权利要求1所述的方法,其特征在于,所述方法还包括:
从所述第一区块头信息中提取梅克尔树,对所述梅克尔树进行检测,当所述梅克尔树中的任一梅克尔值指示不同区块链之间的交易数据时,则确定所述第一区块中包括所述第一区块链与第二区块链之间的跨链交易数据。
3.根据权利要求1所述的方法,其特征在于,所述对所述第一区块头信息进行校验之后,所述方法还包括:
当校验未通过时,基于所述第一区块链系统中发起所述跨链交易的节点设备的节点标识,生成所述节点设备的交易可疑事件记录。
4.根据权利要求1所述的方法,其特征在于,所述跨链交易数据中包括所述第一区块链的链标识、所述第二区块链的链标识、跨链交易在所述第一区块链和所述第二区块链上的合约地址以及跨链交易操作指示信息。
5.根据权利要求4所述的方法,其特征在于,所述将所述跨链交易数据发送至第二区块链系统之后,所述方法还包括:
当接收到所述第二区块链系统的跨链交易结果时,将所述跨链交易结果发送至所述第一区块链系统,由所述第一区块链系统验证通过后进行存储。
6.根据权利要求1所述的方法,其特征在于,所述将所述跨链交易数据发送至所述第二区块链之后,所述方法包括:
向所述第一区块链发送跨链交易提交证明,所述跨链交易提交证明用于指示已经将所述跨链交易提交给所述第二区块链。
7.一种跨区块链的数据信息同步方法,其特征在于,应用于第一区块链系统中的任一个节点设备,所述方法包括:
对第一区块链进行检测;
当检测到所述第一区块链上新增任一区块时,如果所述区块为第一区块,则获取所述第一区块的第一区块头信息,所述第一区块包括所述第一区块链与第二区块链之间的跨链交易数据;
从多个网络设备中选取目标网络设备,所述目标网络设备为所述多个网络设备中当前网络速度最快或者同步成功率满足目标条件的网络设备,所述多个网络设备属于任一家由第一区块链系统和第二区块链系统信任的机构;
向所述目标网络设备发送第一区块头信息,所述第一区块头信息用于指示所述第一区块链上新生成的所述第一区块,所述目标网络设备用于当基于所述第一区块头信息确定所述第一区块包括所述第一区块链与第二区块链之间的跨链交易数据时,根据存储有所述第一区块链的区块头信息的第一数据库,对所述第一区块头信息进行校验,当校验通过时,基于所述第一区块头信息,从所述第一区块中获取跨链交易数据,将所述跨链交易数据发送至第二区块链系统,由所述第二区块链系统在所述跨链交易数据校验通过后基于所述跨链交易数据执行跨链交易。
8.根据权利要求7所述的方法,其特征在于,所述方法还包括:
当接收到所述目标网络设备发送的跨链交易数据时,根据所述跨链交易数据执行跨链交易,将跨链交易结果通过所述目标网络设备发送至所述第二区块链系统。
9.一种跨区块链的数据信息同步装置,其特征在于,所述装置设置于网络设备,所述网络设备不属于第一区块链系统和第二区块链系统,且所述网络设备为所述第一区块链系统从设置的多个网络设备中选取的当前网络速度最快的网络设备,或者同步成功率满足目标条件的网络设备,所述多个网络设备属于任一家由所述第一区块链系统和所述第二区块链系统信任的机构,所述装置包括:
获取模块,用于获取第一区块链系统的第一区块头信息,所述第一区块头信息用于指示第一区块链上新生成的第一区块,所述第一区块头信息是由所述第一区块链系统中的任一个节点设备发送的,其中,所述任一节点设备用于对所述第一区块链进行检测,当检测到所述第一区块链上新增任一区块时,如果所述区块为所述第一区块,则获取所述第一区块的第一区块头信息,向所述网络设备发送所述第一区块头信息;
校验模块,用于当基于所述第一区块头信息确定所述第一区块包括所述第一区块链与第二区块链之间的跨链交易数据时,根据存储有所述第一区块链的区块头信息的第一数据库,对所述第一区块头信息进行校验;
获取模块,用于当校验通过时,基于所述第一区块头信息,从所述第一区块中获取跨链交易数据;
发送模块,用于将所述跨链交易数据发送至第二区块链系统,由所述第二区块链系统在所述跨链交易数据校验通过后基于所述跨链交易数据执行跨链交易。
10.一种跨区块链的数据信息同步装置,其特征在于,所述装置包括:
检测模块,用于对第一区块链进行检测;
获取模块,用于当检测到所述第一区块链上新增任一区块时,如果所述区块为第一区块,则获取所述第一区块的第一区块头信息,所述第一区块包括所述第一区块链与第二区块链之间的跨链交易数据;
发送模块,用于从多个网络设备中选取目标网络设备,所述目标网络设备为所述多个网络设备中当前网络速度最快或者同步成功率满足目标条件的网络设备,所述多个网络设备属于任一家由第一区块链系统和第二区块链系统信任的机构;
所述发送模块,还用于向所述目标网络设备发送第一区块头信息,所述第一区块头信息用于指示所述第一区块链上新生成的所述第一区块,所述目标网络设备用于当基于所述第一区块头信息确定所述第一区块包括所述第一区块链与第二区块链之间的跨链交易数据时,根据存储有所述第一区块链的区块头信息的第一数据库,对所述第一区块头信息进行校验,当校验通过时,基于所述第一区块头信息,从所述第一区块中获取跨链交易数据,将所述跨链交易数据发送至第二区块链系统,由所述第二区块链系统在所述跨链交易数据校验通过后基于所述跨链交易数据执行跨链交易。
11.一种网络设备,其特征在于,所述网络设备包括处理器和存储器,所述存储器中存储有至少一条程序代码,所述程序代码由所述处理器加载并执行以实现如权利要求1至权利要求8任一项所述的跨区块链的数据信息同步所执行的操作。
12.一种计算机可读存储介质,其特征在于,所述存储介质中存储有至少一条指令,所述指令由处理器加载并执行以实现如权利要求1至权利要求8任一项所述的跨区块链的数据信息同步所执行的操作。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910854471.1A CN110597907B (zh) | 2019-09-10 | 2019-09-10 | 跨区块链的数据信息同步方法、装置、设备及介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910854471.1A CN110597907B (zh) | 2019-09-10 | 2019-09-10 | 跨区块链的数据信息同步方法、装置、设备及介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN110597907A CN110597907A (zh) | 2019-12-20 |
CN110597907B true CN110597907B (zh) | 2021-10-29 |
Family
ID=68858656
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910854471.1A Active CN110597907B (zh) | 2019-09-10 | 2019-09-10 | 跨区块链的数据信息同步方法、装置、设备及介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110597907B (zh) |
Families Citing this family (15)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111181968B (zh) * | 2019-12-30 | 2021-09-21 | 北京金山云网络技术有限公司 | 跨区块链通信方法、装置、跨链服务系统及跨链交易系统 |
CN111489161A (zh) * | 2020-04-20 | 2020-08-04 | 北京俩撇科技有限公司 | 一种区块链系统、登记、跨链方法及装置 |
WO2021229691A1 (ja) * | 2020-05-12 | 2021-11-18 | 富士通株式会社 | 制御方法、制御プログラムおよび情報処理装置 |
CN111694852A (zh) * | 2020-05-28 | 2020-09-22 | 平安科技(深圳)有限公司 | 基于分布式事务的数据处理方法、装置、终端及存储介质 |
EP4177804A4 (en) * | 2020-07-02 | 2023-08-09 | Fujitsu Limited | CONTROL METHOD, INFORMATION PROCESSING DEVICE AND CONTROL PROGRAM |
CN111769958B (zh) * | 2020-09-02 | 2021-01-01 | 百度在线网络技术(北京)有限公司 | 区块链跨链处理方法、装置、设备和存储介质 |
CN112202863B (zh) * | 2020-09-24 | 2022-09-20 | 成都质数斯达克科技有限公司 | 数据同步方法、装置、电子设备及可读存储介质 |
CN112184436B (zh) * | 2020-09-24 | 2021-07-16 | 成都质数斯达克科技有限公司 | 数据同步方法、电子设备及可读存储介质 |
CN112241436A (zh) * | 2020-10-26 | 2021-01-19 | 云账户技术(天津)有限公司 | 一种区块链网络的切换方法及装置 |
CN114567643B (zh) * | 2020-11-27 | 2023-05-23 | 腾讯科技(深圳)有限公司 | 跨区块链的数据流转方法、装置及相关设备 |
CN113129146B (zh) * | 2021-03-31 | 2023-11-24 | 南京质子链科技有限公司 | 智能合约事务处理方法、设备及存储介质 |
CN113923232B (zh) * | 2021-06-02 | 2024-03-19 | 支付宝(杭州)信息技术有限公司 | 区块链子网的信息同步方法及装置 |
CN113450113B (zh) * | 2021-06-28 | 2023-05-09 | 上海计算机软件技术开发中心 | 一种跨链交互的智能合约交互模型及协同执行系统 |
CN113852698B (zh) * | 2021-12-01 | 2022-02-08 | 湖南宸瀚信息科技有限责任公司 | 一种群组协同的区块链数据同步系统 |
CN114006911B (zh) * | 2021-12-31 | 2022-04-26 | 杭州趣链科技有限公司 | 数据处理方法、装置、终端设备及存储介质 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107909369A (zh) * | 2017-10-13 | 2018-04-13 | 布比(北京)网络技术有限公司 | 基于跨链交易的共识方法、装置和存储介质 |
CN108805704A (zh) * | 2018-05-16 | 2018-11-13 | 深圳市网心科技有限公司 | 区块链业务实现方法、监听设备、存储介质及系统 |
CN109189853A (zh) * | 2018-08-08 | 2019-01-11 | 众安信息技术服务有限公司 | 一种区块链之间数据同步方法与装置 |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10762479B2 (en) * | 2017-04-05 | 2020-09-01 | Samsung Sds Co., Ltd. | Method and system for processing blockchain-based real-time transaction |
US10255342B2 (en) * | 2017-04-12 | 2019-04-09 | Vijay K. Madisetti | Method and system for tuning blockchain scalability, decentralization, and security for fast and low-cost payment and transaction processing |
CN108415784B (zh) * | 2018-02-27 | 2020-04-24 | 阿里巴巴集团控股有限公司 | 跨区块链的交互方法及装置、系统、电子设备 |
-
2019
- 2019-09-10 CN CN201910854471.1A patent/CN110597907B/zh active Active
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107909369A (zh) * | 2017-10-13 | 2018-04-13 | 布比(北京)网络技术有限公司 | 基于跨链交易的共识方法、装置和存储介质 |
CN108805704A (zh) * | 2018-05-16 | 2018-11-13 | 深圳市网心科技有限公司 | 区块链业务实现方法、监听设备、存储介质及系统 |
CN109189853A (zh) * | 2018-08-08 | 2019-01-11 | 众安信息技术服务有限公司 | 一种区块链之间数据同步方法与装置 |
Also Published As
Publication number | Publication date |
---|---|
CN110597907A (zh) | 2019-12-20 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110597907B (zh) | 跨区块链的数据信息同步方法、装置、设备及介质 | |
CN109831514B (zh) | 平行链共识方法、数据异常处理方法、设备和存储介质 | |
US11632441B2 (en) | Methods, systems, and devices for electronic note identifier allocation and electronic note generation | |
CN108182581B (zh) | 一种区块链的记账方法及装置 | |
US10747721B2 (en) | File management/search system and file management/search method based on block chain | |
CN111383021B (zh) | 基于区块链网络的节点管理方法、装置、设备及介质 | |
CN110505065B (zh) | 一种可信时间戳添加方法、装置和存储介质 | |
CN111767578B (zh) | 一种数据检验方法、装置及设备 | |
CN111597567B (zh) | 数据处理方法、装置、节点设备及存储介质 | |
CN110086780B (zh) | 基于以太坊的被篡改交易的处理方法、装置及存储介质 | |
CN111949531B (zh) | 区块链网络的测试方法、装置、介质及电子设备 | |
CN115859343A (zh) | 一种交易数据处理方法、装置以及可读存储介质 | |
CN111967061B (zh) | 基于区块链的可信账户转账交易方法及装置 | |
CN112184436B (zh) | 数据同步方法、电子设备及可读存储介质 | |
CN110619022B (zh) | 基于区块链网络的节点检测方法、装置、设备及存储介质 | |
CN111224782B (zh) | 基于数字签名的数据校验方法、智能设备及存储介质 | |
CN111339551B (zh) | 数据的验证方法及相关装置、设备 | |
CN113254306B (zh) | 运行状态监控方法、装置、设备和存储介质 | |
CN113904869B (zh) | 一种区块链中恶意节点的检测方法及区块链 | |
CN110351273B (zh) | 一种网络追踪长链条攻击的方法、装置和系统 | |
WO2022205957A1 (zh) | 一种基于中继设备跨链中转消息的方法和装置 | |
CN112202863B (zh) | 数据同步方法、装置、电子设备及可读存储介质 | |
CN112258184B (zh) | 冻结区块链网络的方法、装置、电子设备及可读存储介质 | |
CN114489995A (zh) | 一种分布式调度处理方法及系统 | |
CN113014587A (zh) | 一种api检测方法、装置、电子设备及存储介质 |
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 |