CN114584474A - 联盟区块链及分层部署方法 - Google Patents
联盟区块链及分层部署方法 Download PDFInfo
- Publication number
- CN114584474A CN114584474A CN202210211954.1A CN202210211954A CN114584474A CN 114584474 A CN114584474 A CN 114584474A CN 202210211954 A CN202210211954 A CN 202210211954A CN 114584474 A CN114584474 A CN 114584474A
- Authority
- CN
- China
- Prior art keywords
- layer module
- node
- module
- target data
- error correction
- 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
Links
- 238000000034 method Methods 0.000 title claims abstract description 63
- 238000012937 correction Methods 0.000 claims description 122
- 230000004044 response Effects 0.000 claims description 33
- 230000008569 process Effects 0.000 claims description 24
- 238000010200 validation analysis Methods 0.000 claims description 6
- 238000012545 processing Methods 0.000 claims description 3
- 230000000977 initiatory effect Effects 0.000 claims description 2
- 239000010410 layer Substances 0.000 description 290
- 238000013461 design Methods 0.000 description 7
- 238000010586 diagram Methods 0.000 description 7
- 238000011161 development Methods 0.000 description 5
- 230000006870 function Effects 0.000 description 5
- 238000012423 maintenance Methods 0.000 description 4
- 230000008520 organization Effects 0.000 description 4
- 230000008878 coupling Effects 0.000 description 3
- 238000010168 coupling process Methods 0.000 description 3
- 238000005859 coupling reaction Methods 0.000 description 3
- 238000005516 engineering process Methods 0.000 description 3
- 238000012795 verification Methods 0.000 description 3
- 238000004891 communication Methods 0.000 description 2
- 238000012790 confirmation Methods 0.000 description 2
- 239000004744 fabric Substances 0.000 description 2
- 238000013459 approach Methods 0.000 description 1
- 238000004590 computer program Methods 0.000 description 1
- 230000007547 defect Effects 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- 230000002452 interceptive effect Effects 0.000 description 1
- 238000011835 investigation Methods 0.000 description 1
- 239000011159 matrix material Substances 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 239000002356 single layer Substances 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/14—Network analysis or design
- H04L41/145—Network analysis or design involving simulating, designing, planning or modelling of a network
-
- 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
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L1/00—Arrangements for detecting or preventing errors in the information received
- H04L1/004—Arrangements for detecting or preventing errors in the information received by using forward error control
- H04L1/0056—Systems characterized by the type of code used
- H04L1/0061—Error detection codes
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Databases & Information Systems (AREA)
- Theoretical Computer Science (AREA)
- Computing Systems (AREA)
- Data Mining & Analysis (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Information Transfer Between Computers (AREA)
Abstract
本申请提供一种联盟区块链及分层部署方法,该方法包括:当联盟区块链的第三层模块中的节点接收到目标数据时,将所述目标数据上传至所述第三层模块中的节点对应的第二层模块中的节点;其中,所述目标数据包括业务部署需求及所述业务部署需求所需要的数据;当所述联盟区块链的第二层模块中的节点接收到目标数据时,将所述目标数据上传至所述第二层模块中的节点对应的第一层模块中的节点;当所述联盟区块链的第一层模块中的节点接收到目标数据时,利用所述目标数据在联盟区块链中进行部署。从而在满足分层的部署结构的同时无需对联盟链框架进行大量修改的目的。
Description
技术领域
本申请涉及区块链技术领域,特别涉及一种联盟区块链及分层部署方法。
背景技术
目前的联盟区块链部署方案基本采用单层的方法,不论是基于HyperledgerFabric的部署方法还是基于金融区块链合作联盟的FISCO-BCOS框架的部署方法,每个节点都是平等的节点,共同维护区块链。
但是,在许多部署场景中,并非所有的节点都是平等的节点,因此采用完全扁平的部署方案不能满足所有应用部署场景。在银行的应用部署场景中,存在不同级别的组织机构,包括农村部署在商户的助农服务点,省市级分行以及总行机构。不同级别的硬件设备以及机房拥有不同水平的运维措施和网络条件,在这种情况下扁平架构的部署方法将不适用。另外,有一些结构采用了轻节点/全节点的设计方案来降低存储冗余和提高性能,但是在此类设计下,轻节点要么不参与共识只做验证,要么在共识算法中仍为和全节点平等的节点,不符合银行不同级别计算设备的性能和容量,同样不符合不同等级网点或分行的管理地位。
发明内容
有鉴于此,本申请提供一种联盟区块链及分层部署方法,针对银行多层部署区块链的场景,提出了多层部署,不同层次间交互又不耦合的设计方法,以便于开发工作进行,并降低开发成本。
本申请第一方面提供了一种联盟区块链,包括:
联盟区块链的第一层模块、联盟区块链的第二层模块以及联盟区块链的第三层模块;其中,所述联盟区块链的第一层模块部署有联盟链框架节点;所述联盟区块链的第二层模块以及所述联盟区块链的第三层模块部署有附属节点;
所述联盟区块链的第三层模块中的节点,用于接收到目标数据时,将所述目标数据上传至所述第三层模块中的节点对应的第二层模块中的节点;其中,所述目标数据包括业务部署需求及所述业务部署需求所需要的数据;
所述联盟区块链的第二层模块中的节点,用于当接收到所述目标数据时,将所述目标数据上传至所述第二层模块中的节点对应的第一层模块中的节点;
所述联盟区块链的第一层模块中的节点,用于当接收到所述目标数据时,利用所述目标数据在联盟区块链中进行部署。
可选的,所述联盟区块链的第一层模块中的节点用于当接收到所述目标数据时,利用所述目标数据在联盟区块链中进行部署时,包括:
接收模块,用于接收所述目标数据;
处理模块,用于对所述目标数据进行转发或广播,通知联盟区块链中的每一个节点对所述目标数据进行确认和部署。
可选的,所述联盟区块链,还包括:
纠错模块,部署于联盟区块链的第二层模块以及联盟区块链的第三层模块;
第二层模块的纠错模块,用于在第二层模块将所述目标数据上传至所述第二层模块中的节点对应的第一层模块中的节点的过程中,未收到正确的反馈信息时,将未收到正确的反馈信息对应的数据重新上传至第二层模块中的节点对应的第一层模块中除故障节点外的所有节点;
第三层模块的纠错模块,用于在第三层模块将所述目标数据上传至所述第三层模块中的节点对应的第二层模块中的节点的过程中,未收到正确的反馈信息时,将未收到正确的反馈信息对应的数据重新上传至第三层模块中的节点对应的第二层模块中除故障节点外的所有节点。
可选的,所述联盟区块链,还包括:
纠错响应模块,部署于联盟区块链的第一层模块的节点以及联盟区块链的第二层模块的节点中;
第二层模块的节点的纠错响应模块,用于在第二层模块中检查目标数据是否正确完成目标操作;其中,所述目标操作包括:部署和/或确认;
若目标数据正确完成目标操作,则反馈正确的反馈信息至第三层模块的纠错模块;
若目标数据未正确完成目标操作,则重新向第一层模块发起上传请求;
第一层模块的节点的纠错响应模块,用于在第一层模块中检查目标数据是否正确完成目标操作;
若目标数据正确完成目标操作,则反馈正确的反馈信息至第二层模块的纠错模块;
若目标数据未正确完成目标操作,则重新进行所述目标操作。
可选的,所述第二层模块的节点的纠错响应模块,用于在第二层模块中检查目标数据是否正确完成目标操作时,包括:
第一接收模块,用于接收第一纠错请求;
第一校验模块,用于对所述第一纠错请求进行校验,得到第一校验结果;
第一确定模块,用于若所述第一校验结果表明所述第一纠错请求中的错误的确存在,则在第二层模块中的节点之间进行共识,根据共识结果确定是否正确完成目标操作。
可选的,所述第一层模块的节点的纠错响应模块,用于在第一层模块中检查目标数据是否正确完成目标操作时,包括:
第二接收模块,用于接收第二纠错请求;
判断模块,用于判断所述第二纠错请求是否来自所述第一层模块的节点的下属第二层模块的节点;
第二校验模块,用于若所述判断模块判断出所述第二纠错请求来自所述第一层模块的节点的下属第二层模块的节点,则校验所述第二纠错请求的签名并计算第一签名数量;
第二确定单元,用于若所述第一签名数量大于第一阈值,确定目标数据未正确完成目标操作;其中,所述第一阈值为所述第一层模块的节点的下属第二层模块的节点数量的预设百分比;
所述第二校验模块,还用于若所述判断模块判断出所述第二纠错请求不来自所述第一层模块的节点的下属第二层模块的节点,则校验所述第二纠错请求的签名并计算第二签名数量;
所述第二确定单元,还用于若所述第二签名数量大于第二阈值,确定目标数据未正确完成目标操作;其中,所述第二阈值为所有第二层模块的节点数量的预设百分比。
本申请第二方面提供了一种分层部署方法,包括:
当联盟区块链的第三层模块中的节点接收到目标数据时,将所述目标数据上传至所述第三层模块中的节点对应的第二层模块中的节点;其中,所述目标数据包括业务部署需求及所述业务部署需求所需要的数据;
当所述联盟区块链的第二层模块中的节点接收到目标数据时,将所述目标数据上传至所述第二层模块中的节点对应的第一层模块中的节点;
当所述联盟区块链的第一层模块中的节点接收到目标数据时,利用所述目标数据在联盟区块链中进行部署。
可选的,所述当所述联盟区块链的第一层模块中的节点接收到目标数据时,利用所述目标数据在联盟区块链中进行部署,包括:
所述联盟区块链的第一层模块中的节点接收到目标数据;
对所述目标数据进行转发或广播,通知联盟区块链中的每一个节点对所述目标数据进行确认和部署。
可选的,所述分层部署方法,还包括:
在第二层模块将所述目标数据上传至所述第二层模块中的节点对应的第一层模块中的节点的过程中,未收到正确的反馈信息时,通过第二层模块的纠错模块将未收到正确的反馈信息对应的数据重新上传至第二层模块中的节点对应的第一层模块中除故障节点外的所有节点;
在第三层模块将所述目标数据上传至所述第三层模块中的节点对应的第二层模块中的节点的过程中,未收到正确的反馈信息时,通过第三层模块的纠错模块将未收到正确的反馈信息对应的数据重新上传至第三层模块中的节点对应的第二层模块中除故障节点外的所有节点。
可选的,所述分层部署方法,还包括:
通过第二层模块的节点的纠错响应模块在第二层模块中检查目标数据是否正确完成目标操作;其中,所述目标操作包括:部署和/或确认;
若目标数据正确完成目标操作,则反馈正确的反馈信息至第三层模块的纠错模块;
若目标数据未正确完成目标操作,则重新向第一层模块发起上传请求;
通过第一层模块的节点的纠错响应模块检查目标数据是否正确完成目标操作;
若目标数据正确完成目标操作,则反馈正确的反馈信息至第二层模块的纠错模块;
若目标数据未正确完成目标操作,则重新进行所述目标操作。
可选的,所述通过第二层模块的节点的纠错响应模块在第二层模块中检查目标数据是否正确完成目标操作,包括:
接收第一纠错请求;
对所述第一纠错请求进行校验,得到第一校验结果;
若所述第一校验结果表明所述第一纠错请求中的错误的确存在,则在第二层模块中的节点之间进行共识,根据共识结果确定是否正确完成目标操作。
可选的,所述通过第一层模块的节点的纠错响应模块检查目标数据是否正确完成目标操作,包括:
接收第二纠错请求;
判断所述第二纠错请求是否来自所述第一层模块的节点的下属第二层模块的节点;
若所述判断出所述第二纠错请求来自所述第一层模块的节点的下属第二层模块的节点,则校验所述第二纠错请求的签名并计算第一签名数量;
若所述第一签名数量大于第一阈值,确定目标数据未正确完成目标操作;其中,所述第一阈值为所述第一层模块的节点的下属第二层模块的节点数量的预设百分比;
若所述判断出所述第二纠错请求不来自所述第一层模块的节点的下属第二层模块的节点,则校验所述第二纠错请求的签名并计算第二签名数量;
若所述第二签名数量大于第二阈值,确定目标数据未正确完成目标操作;其中,所述第二阈值为所有第二层模块的节点数量的预设百分比。
由以上方案可知,本申请提供的一种联盟区块链及分层部署方法,所述联盟区块链包括:联盟区块链的第一层模块、联盟区块链的第二层模块以及联盟区块链的第三层模块;其中,所述联盟区块链的第一层模块部署有联盟链框架节点;所述联盟区块链的第二层模块以及所述联盟区块链的第三层模块部署有附属节点;所述联盟区块链的第三层模块中的节点,用于接收到目标数据时,将所述目标数据上传至所述第三层模块中的节点对应的第二层模块中的节点;其中,所述目标数据包括业务部署需求及所述业务部署需求所需要的数据;所述联盟区块链的第二层模块中的节点,用于当接收到所述目标数据时,将所述目标数据上传至所述第二层模块中的节点对应的第一层模块中的节点;所述联盟区块链的第一层模块中的节点,用于当接收到所述目标数据时,利用所述目标数据在联盟区块链中进行部署。从而在满足分层的部署结构的同时无需对联盟链框架进行大量修改的目的。
附图说明
为了更清楚地说明本申请实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据提供的附图获得其他的附图。
图1为本申请实施例中提供的一种联盟区块链的示意图;
图2为本申请另一实施例中提供的一种联盟区块链的示意图;
图3为本申请另一实施例中提供的一种分层部署方法的具体流程图。
具体实施方式
下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。
需要注意,本申请中提及的“第一”、“第二”等概念仅用于对不同的装置、模块或单元进行区分,并非用于限定这些装置、模块或单元所执行的功能的顺序或者相互依存关系,而术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
首先,本申请中涉及到的通用技术和知识进行介绍:
HyperledgerFabric超级账本联盟链框架。
超级账本(hyperledger)是Linux基金会于2015年发起的推进区块链数字技术和交易验证的开源项目,30家初始企业成员(包括IBM、Intel、J.P.Morgan、Cisco等)。目标是让成员共同合作,满足不同行业案例,简化业务流程。超级账本的peer节点部署是扁平的,每个peer承担完全相同的作用,拥有相同的地位。
FISCO-BCOS,FISCO-BCOS起源于微众银行和万向区块链、矩阵元共同推出的BCOS,BCOS在2017年7月完全开源,随后又跟其他机构一起推出了BCOS的金融版本:FISCO-BCOS。聚焦区块链应用场景的落地,在包括供应链、票据、数据共享、资产证券化、征信、场外股权市场等场景进行实践。
以太坊等公链技术,以太坊支持智能合约,用户可以将编写完成的智能合约部署在以太坊。以太坊是一个去中心化应用的平台,允许任何人在平台中建立和使用通过区块链技术运行的去中心化应用。
目前现有技术中存在以下缺点:
(1)当前以太坊等公有链不适合部署在银行系统中,内部的信息不能被上传至公链;
(2)超级账本和BCOS等联盟链框架采用的扁平式部署方法不适用于存在层次等级的银行组织结构。
(3)已有的一些双链和双层区块链设计并非针对银行应用场景,不满足或者只满足部分银行分层部署的需求。
因此,本申请实施例提供了一种联盟区块链,以解决上述现有技术中的缺点,如图1所示,具体包括:
联盟区块链的第一层模块100、联盟区块链的第二层模块200以及联盟区块链的第三层模块300。
其中,联盟区块链的第一层模块部署有联盟链框架节点,完成全节点任务,例如共识算法、智能合约,以及部署在区块链上的业务;联盟区块链的第二层模块以及联盟区块链的第三层模块部署有附属节点,第二层模块可以将数据如需要部署的智能合约、需要保护的单据等资料上传至第一层模块中的一个或数个全节点,然后由全节点进行转发与广播,再通知到网络中的所有节点。第三层模块可以直接将业务部署需求上传至第二层模块,由第二层模块转发至第一层模块进行部署。
在本申请的实际应用的过程中,联盟区块链的示意图可以如图2所示,联盟区块链的第一层模块100(即图2中的第一层联盟链)可以部署但不限于在银行高可用云平台或者省分行机房;联盟区块链的第二层模块200(即图2中的第二层)可以部署但不限于在各市、县等运维能力较弱、响应延迟较高的营业部;联盟区块链的第三层模块300(即图2中的第三层)可以部署但不限于在基本无运维能力、响应延迟很高、容易被网络入侵和物理入侵的农村营业部。
需要说明的是,第二层包括某分行下属的支行机房以及一台或者少量第一层的设备,例如,一台分行机房设备既是第一层的设备,同时也是第二层的设备,两层在这台分行机房设备上交叉。第三层和第二层没有交叉,第三层的设备和第二层不存在交叉,正常情况下,第三层的设备只连接到一台第二层的设备,例如支行机房,但是出现错误时可能会与其他第二层设备进行通信。
具体的,联盟区块链的第三层模块中的节点,用于接收到目标数据时,将目标数据上传至第三层模块中的节点对应的第二层模块中的节点。
其中,目标数据包括业务部署需求及业务部署需求所需要的数据。
联盟区块链的第二层模块中的节点,用于当接收到目标数据时,将目标数据上传至第二层模块中的节点对应的第一层模块中的节点。
联盟区块链的第一层模块中的节点,用于当接收到目标数据时,利用目标数据在联盟区块链中进行部署。
可选的,在本申请的另一实施例中,联盟区块链的第一层模块中的节点用于当接收到目标数据时,利用目标数据在联盟区块链中进行部署时的一种实施方式,包括:
接收模块,用于接收目标数据。
处理模块,用于对目标数据进行转发或广播,通知联盟区块链中的每一个节点对目标数据进行确认和部署。
可选的,在本申请的另一实施例中,联盟区块链的一种实施方式,还包括:
纠错模块,部署于联盟区块链的第二层模块以及联盟区块链的第三层模块。
第二层模块的纠错模块,用于在第二层模块将目标数据上传至第二层模块中的节点对应的第一层模块中的节点的过程中,未收到正确的反馈信息时,将未收到正确的反馈信息对应的数据重新上传至第二层模块中的节点对应的第一层模块中除故障节点外的所有节点。并获取纠错响应模块的反馈。
需要说明的是,未收到正确的反馈信息包括但不限于:未得到确认、响应超时等,此处不做限定。
第三层模块的纠错模块,用于在第三层模块将目标数据上传至第三层模块中的节点对应的第二层模块中的节点的过程中,未收到正确的反馈信息时,将未收到正确的反馈信息对应的数据重新上传至第三层模块中的节点对应的第二层模块中除故障节点外的所有节点。并获取纠错响应模块的反馈。
可选的,在本申请的另一实施例中,联盟区块链的一种实施方式,还包括:
纠错响应模块,部署于联盟区块链的第一层模块的节点以及联盟区块链的第二层模块的节点中。
第二层模块的节点的纠错响应模块,用于在第二层模块中检查目标数据是否正确完成目标操作。
其中,目标操作包括:部署和/或确认。
若目标数据正确完成目标操作,则反馈正确的反馈信息至第三层模块的纠错模块。
若目标数据未正确完成目标操作,则重新向第一层模块发起上传请求。
第一层模块的节点的纠错响应模块,用于在第一层模块中检查目标数据是否正确完成目标操作。
若目标数据正确完成目标操作,则反馈正确的反馈信息至第二层模块的纠错模块。
若目标数据未正确完成目标操作,则重新进行目标操作。
可选的,在本申请的另一实施例中,第二层模块的节点的纠错响应模块,用于在第二层模块中检查目标数据是否正确完成目标操作时,包括:
第一接收模块,用于接收第一纠错请求。
第一校验模块,用于对第一纠错请求进行校验,得到第一校验结果。
第一确定模块,用于若第一校验结果表明第一纠错请求中的错误的确存在,则在第二层模块中的节点之间进行共识,根据共识结果确定是否正确完成目标操作。
可选的,在本申请的另一实施例中,第一层模块的节点的纠错响应模块,用于在第一层模块中检查目标数据是否正确完成目标操作时,包括:
第二接收模块,用于接收第二纠错请求。
判断模块,用于判断第二纠错请求是否来自第一层模块的节点的下属第二层模块的节点。
第二校验模块,用于若判断模块判断出第二纠错请求来自第一层模块的节点的下属第二层模块的节点,则校验第二纠错请求的签名并计算第一签名数量。
第二确定单元,用于若第一签名数量大于第一阈值,确定目标数据未正确完成目标操作。
其中,第一阈值为第一层模块的节点的下属第二层模块的节点数量的预设百分比。
第二校验模块,还用于若判断模块判断出第二纠错请求不来自第一层模块的节点的下属第二层模块的节点,则校验第二纠错请求的签名并计算第二签名数量。
第二确定单元,还用于若第二签名数量大于第二阈值,确定目标数据未正确完成目标操作。
其中,第二阈值为所有第二层模块的节点数量的预设百分比。
现对本申请实施例进行举例说明:
联盟区块链的第一层模块,部署常规区块链业务,包括联盟区块链的常用框架,例如Hyperledger Fabric,以太坊,FISCO-BCOS等。当总行和各省分行有区块链业务需求要上线时,直接在全节点部署智能合约,联盟区块链的第一层模块接收上传的数据如智能合约等,智能合约会立即广播至联盟区块链中所有节点并得到确认。
对于非联盟区块链的第一层模块的其他节点,在正确情况下:
当农村营业部需要上线业务或者上传单据至区块链系统时,首先数据会由营业部上传至最近的市直支行服务器,市级服务器转发至省分行单位,最后完成在链上部署。
当市级部门需要上传数据或者部署业务时,会将数据上传至对应的省分行机构,省分行机构在第一层区块链中完成确认和部署。
对于非联盟区块链的第一层模块的其他节点,在出现错误的情况下:
当农村营业部认为未收到正确的响应,例如业务未成功部署至区块链,或者数据未被确认,则向市级服务器提出纠错,纠错过程由纠错模块完成。对于接收到纠错请求的市级单位,其检查纠错请求中的错误是否存在。如果存在,则向请求纠错的服务器反馈“进行纠错”,否则反馈“已确认”。当联盟区块链的第三层模块的纠错模块收到大于2/3的“已确认”后则认为所提出的错误已经事实上被正确地确认,否则等待联盟区块链的第二层模块向联盟区块链的第一层模块发起纠错,并在结束后验证纠错结果。
当联盟区块链的第二层模块所在服务器收到联盟区块链的第三层模块所在服务器的纠错请求时,首先对所请求的纠错需求进行校验,随后在联盟区块链的第二层模块中的节点间进行共识,得到共识结果后每个节点将结果反馈给联盟区块链的第三层模块的纠错模块。如果共识结果为纠错请求中的错误确实存在,则联盟区块链的第二层模块的每个节点给联盟区块链的第三层模块的当地省级服务器提出纠错请求,并对请求进行签名。
如果联盟区块链的第二层模块所在服务器发现自身的请求未得到执行或者未确认,则在联盟区块链的第二层模块中的节点间进行共识,如果共识结果为错误确实存在,则联盟区块链的第二层模块每个节点给联盟区块链的第一层模块的当地省级服务器提出纠错请求,并对请求进行签名。如果在联盟区块链的第二层模块向联盟区块链的第一层模块当地省分行机构提出纠错后未得到响应,则每个节点向所有联盟区块链的第一层模块的每个服务器提出纠错请求,并对请求进行签名。
当联盟区块链的第一层模块所在服务器收到其下属联盟区块链的第二层模块所在服务器的纠错请求时,校验请求签名并计算数量,如果数量大于2/3则在联盟区块链的第一层模块中重新提起请求的部署,即,将请求转发至其他所有节点,然后进行共识确认。如果联盟区块链的第一层模块所在服务器收到非其下属的联盟区块链的第一层模块所在服务器的纠错请求时,校验签名并计算数量,如果数量大于第二层总节点数量的2/3,直接进入共识。
可以看出,本申请针对银行多层部署区块链的场景,提出了多层部署方案。并针对银行不同级别水平的不同,为每层设计了不同的协议,以达到:降低低层对高层发起攻击的概率,同时保留低层对高层的通信通道,在确实出现错误时可以影响高一级的决策并向上传递。不同层次间交互又不耦合的设计方法,以便于开发工作进行,并降低开发成本。
本申请最重要的思路在于分层的结构设计,以及第二层、第三层协议的设计。这些结构和协议确保了以下效果:
第一,第一层仍然可以部署常用的联盟链区块链框架,不需要另外进行软件开发,节约开发成本。第二、三层与第一层的区块链可以交互却又不耦合,可以独立开发并接入第一层中,不需要和第一层的框架同时开发。
第二,按照银行的层次组织结构和每个层次所拥有的硬件水平和运维水平,设计了多层的部署方案,次级层次的服务器在正常情况下只能连接有限个数的上层服务器,防止DDoS攻击等不合规的流量,使得易被入侵和控制的农村运营部等部门难以对上层发起攻击。
第三,针对多层的部署方案,设计了相应的纠错协议,确保第二、三层的设备不只是跟随者,可以影响到第一层的智能合约部署。农村营业部可以在出错时影响第二层的决策,第二层在经过验证后可以影响第一层决策,相同地,第二层出错时,可以先在第二层内进行共识,然后对上层重新提出需求。
由以上方案可知,本申请提供的一种联盟区块链,包括:联盟区块链的第一层模块、联盟区块链的第二层模块以及联盟区块链的第三层模块;其中,联盟区块链的第一层模块部署有联盟链框架节点;联盟区块链的第二层模块以及联盟区块链的第三层模块部署有附属节点;联盟区块链的第三层模块中的节点,用于接收到目标数据时,将目标数据上传至第三层模块中的节点对应的第二层模块中的节点;其中,目标数据包括业务部署需求及业务部署需求所需要的数据;联盟区块链的第二层模块中的节点,用于当接收到目标数据时,将目标数据上传至第二层模块中的节点对应的第一层模块中的节点;联盟区块链的第一层模块中的节点,用于当接收到目标数据时,利用目标数据在联盟区块链中进行部署。从而在满足分层的部署结构的同时无需对联盟链框架进行大量修改的目的。
本申请另一实施例提供了一种分层部署方法,如图3所示,具体包括以下步骤:
S001、当联盟区块链的第三层模块中的节点接收到目标数据时,将目标数据上传至第三层模块中的节点对应的第二层模块中的节点。
其中,目标数据包括业务部署需求及业务部署需求所需要的数据。
S002、当联盟区块链的第二层模块中的节点接收到目标数据时,将目标数据上传至第二层模块中的节点对应的第一层模块中的节点。
S003、当联盟区块链的第一层模块中的节点接收到目标数据时,利用目标数据在联盟区块链中进行部署。
本申请上述实施例公开的方法的具体工作过程,可参见对应的装置实施例内容,此处不再赘述。
可选的,在本申请的另一实施例中,步骤S303的一种实施方式,具体包括:
联盟区块链的第一层模块中的节点接收到目标数据。
对目标数据进行转发或广播,通知联盟区块链中的每一个节点对目标数据进行确认和部署。
本申请上述实施例公开的方法的具体工作过程,可参见对应的装置实施例内容,此处不再赘述。
可选的,在本申请的另一实施例中,分层部署方法的一种实施方式,还包括:
在第二层模块将目标数据上传至第二层模块中的节点对应的第一层模块中的节点的过程中,未收到正确的反馈信息时,通过第二层模块的纠错模块将未收到正确的反馈信息对应的数据重新上传至第二层模块中的节点对应的第一层模块中除故障节点外的所有节点。
在第三层模块将目标数据上传至第三层模块中的节点对应的第二层模块中的节点的过程中,未收到正确的反馈信息时,通过第三层模块的纠错模块将未收到正确的反馈信息对应的数据重新上传至第三层模块中的节点对应的第二层模块中除故障节点外的所有节点。
本申请上述实施例公开的方法的具体工作过程,可参见对应的装置实施例内容,此处不再赘述。
可选的,在本申请的另一实施例中,分层部署方法的一种实施方式,还包括:
通过第二层模块的节点的纠错响应模块在第二层模块中检查目标数据是否正确完成目标操作。
其中,目标操作包括:部署和/或确认。
若目标数据正确完成目标操作,则反馈正确的反馈信息至第三层模块的纠错模块。
若目标数据未正确完成目标操作,则重新向第一层模块发起上传请求。
通过第一层模块的节点的纠错响应模块检查目标数据是否正确完成目标操作。
若目标数据正确完成目标操作,则反馈正确的反馈信息至第二层模块的纠错模块。
若目标数据未正确完成目标操作,则重新进行目标操作。
本申请上述实施例公开的方法的具体工作过程,可参见对应的装置实施例内容,此处不再赘述。
可选的,在本申请的另一实施例中,通过第二层模块的节点的纠错响应模块在第二层模块中检查目标数据是否正确完成目标操作的一种实施方式,还包括:
接收第一纠错请求。
对第一纠错请求进行校验,得到第一校验结果。
若第一校验结果表明第一纠错请求中的错误的确存在,则在第二层模块中的节点之间进行共识,根据共识结果确定是否正确完成目标操作。
本申请上述实施例公开的方法的具体工作过程,可参见对应的装置实施例内容,此处不再赘述。
可选的,在本申请的另一实施例中,通过第一层模块的节点的纠错响应模块检查目标数据是否正确完成目标操作的一种实施方式,包括:
接收第二纠错请求。
判断第二纠错请求是否来自第一层模块的节点的下属第二层模块的节点。
若判断出第二纠错请求来自第一层模块的节点的下属第二层模块的节点,则校验第二纠错请求的签名并计算第一签名数量。
若第一签名数量大于第一阈值,确定目标数据未正确完成目标操作。
其中,第一阈值为第一层模块的节点的下属第二层模块的节点数量的预设百分比。
若判断出第二纠错请求不来自第一层模块的节点的下属第二层模块的节点,则校验第二纠错请求的签名并计算第二签名数量。
若第二签名数量大于第二阈值,确定目标数据未正确完成目标操作。
其中,第二阈值为所有第二层模块的节点数量的预设百分比。
本申请上述实施例公开的方法的具体工作过程,可参见对应的装置实施例内容,此处不再赘述。
由以上方案可知,本申请提供一种分层部署方法:当联盟区块链的第三层模块中的节点接收到目标数据时,将目标数据上传至第三层模块中的节点对应的第二层模块中的节点;其中,目标数据包括业务部署需求及业务部署需求所需要的数据;当联盟区块链的第二层模块中的节点接收到目标数据时,将目标数据上传至第二层模块中的节点对应的第一层模块中的节点;当联盟区块链的第一层模块中的节点接收到目标数据时,利用目标数据在联盟区块链中进行部署。从而在满足分层的部署结构的同时无需对联盟链框架进行大量修改的目的。
在本申请公开的上述实施例中,应该理解到,所揭露的装置和方法,也可以通过其它的方式实现。以上所描述的装置和方法实施例仅仅是示意性的,例如,附图中的流程图和框图显示了根据本公开的多个实施例的装置、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段或代码的一部分,所述模块、程序段或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现方式中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个连续的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或动作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
另外,在本公开各个实施例中的各功能模块可以集成在一起形成一个独立的部分,也可以是各个模块单独存在,也可以两个或两个以上模块集成形成一个独立的部分。所述功能如果以软件功能模块的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本公开的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,直播设备,或者网络设备等)执行本公开各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(ROM,Read-OnlyMemory)、随机存取存储器(RAM,RandomAccess Memory)、磁碟或者光盘等各种可以存储程序代码的介质。
专业技术人员能够实现或使用本申请。对这些实施例的多种修改对本领域的专业技术人员来说将是显而易见的,本文中所定义的一般原理可以在不脱离本申请的精神或范围的情况下,在其它实施例中实现。因此,本申请将不会被限制于本文所示的这些实施例,而是要符合与本文所公开的原理和新颖特点相一致的最宽的范围。
Claims (10)
1.一种联盟区块链,其特征在于,包括:
联盟区块链的第一层模块、联盟区块链的第二层模块以及联盟区块链的第三层模块;其中,所述联盟区块链的第一层模块部署有联盟链框架节点;所述联盟区块链的第二层模块以及所述联盟区块链的第三层模块部署有附属节点;
所述联盟区块链的第三层模块中的节点,用于接收到目标数据时,将所述目标数据上传至所述第三层模块中的节点对应的第二层模块中的节点;其中,所述目标数据包括业务部署需求及所述业务部署需求所需要的数据;
所述联盟区块链的第二层模块中的节点,用于当接收到所述目标数据时,将所述目标数据上传至所述第二层模块中的节点对应的第一层模块中的节点;
所述联盟区块链的第一层模块中的节点,用于当接收到所述目标数据时,利用所述目标数据在联盟区块链中进行部署。
2.根据权利要求1所述的联盟区块链,其特征在于,所述联盟区块链的第一层模块中的节点用于当接收到所述目标数据时,利用所述目标数据在联盟区块链中进行部署时,包括:
接收模块,用于接收所述目标数据;
处理模块,用于对所述目标数据进行转发或广播,通知联盟区块链中的每一个节点对所述目标数据进行确认和部署。
3.根据权利要求1所述的联盟区块链,其特征在于,还包括:
纠错模块,部署于联盟区块链的第二层模块以及联盟区块链的第三层模块;
第二层模块的纠错模块,用于在第二层模块将所述目标数据上传至所述第二层模块中的节点对应的第一层模块中的节点的过程中,未收到正确的反馈信息时,将未收到正确的反馈信息对应的数据重新上传至第二层模块中的节点对应的第一层模块中除故障节点外的所有节点;
第三层模块的纠错模块,用于在第三层模块将所述目标数据上传至所述第三层模块中的节点对应的第二层模块中的节点的过程中,未收到正确的反馈信息时,将未收到正确的反馈信息对应的数据重新上传至第三层模块中的节点对应的第二层模块中除故障节点外的所有节点。
4.根据权利要求3所述的联盟区块链,其特征在于,还包括:
纠错响应模块,部署于联盟区块链的第一层模块的节点以及联盟区块链的第二层模块的节点中;
第二层模块的节点的纠错响应模块,用于在第二层模块中检查目标数据是否正确完成目标操作;其中,所述目标操作包括:部署和/或确认;
若目标数据正确完成目标操作,则反馈正确的反馈信息至第三层模块的纠错模块;
若目标数据未正确完成目标操作,则重新向第一层模块发起上传请求;
第一层模块的节点的纠错响应模块,用于在第一层模块中检查目标数据是否正确完成目标操作;
若目标数据正确完成目标操作,则反馈正确的反馈信息至第二层模块的纠错模块;
若目标数据未正确完成目标操作,则重新进行所述目标操作。
5.根据权利要求4所述的联盟区块链,其特征在于,所述第二层模块的节点的纠错响应模块,用于在第二层模块中检查目标数据是否正确完成目标操作时,包括:
第一接收模块,用于接收第一纠错请求;
第一校验模块,用于对所述第一纠错请求进行校验,得到第一校验结果;
第一确定模块,用于若所述第一校验结果表明所述第一纠错请求中的错误的确存在,则在第二层模块中的节点之间进行共识,根据共识结果确定是否正确完成目标操作。
6.根据权利要求4所述的联盟区块链,其特征在于,所述第一层模块的节点的纠错响应模块,用于在第一层模块中检查目标数据是否正确完成目标操作时,包括:
第二接收模块,用于接收第二纠错请求;
判断模块,用于判断所述第二纠错请求是否来自所述第一层模块的节点的下属第二层模块的节点;
第二校验模块,用于若所述判断模块判断出所述第二纠错请求来自所述第一层模块的节点的下属第二层模块的节点,则校验所述第二纠错请求的签名并计算第一签名数量;
第二确定单元,用于若所述第一签名数量大于第一阈值,确定目标数据未正确完成目标操作;其中,所述第一阈值为所述第一层模块的节点的下属第二层模块的节点数量的预设百分比;
所述第二校验模块,还用于若所述判断模块判断出所述第二纠错请求不来自所述第一层模块的节点的下属第二层模块的节点,则校验所述第二纠错请求的签名并计算第二签名数量;
所述第二确定单元,还用于若所述第二签名数量大于第二阈值,确定目标数据未正确完成目标操作;其中,所述第二阈值为所有第二层模块的节点数量的预设百分比。
7.一种分层部署方法,其特征在于,应用于联盟区块链,包括:
当联盟区块链的第三层模块中的节点接收到目标数据时,将所述目标数据上传至所述第三层模块中的节点对应的第二层模块中的节点;其中,所述目标数据包括业务部署需求及所述业务部署需求所需要的数据;
当所述联盟区块链的第二层模块中的节点接收到目标数据时,将所述目标数据上传至所述第二层模块中的节点对应的第一层模块中的节点;
当所述联盟区块链的第一层模块中的节点接收到目标数据时,利用所述目标数据在联盟区块链中进行部署。
8.根据权利要求7所述的分层部署方法,其特征在于,所述当所述联盟区块链的第一层模块中的节点接收到目标数据时,利用所述目标数据在联盟区块链中进行部署,包括:
所述联盟区块链的第一层模块中的节点接收到目标数据;
对所述目标数据进行转发或广播,通知联盟区块链中的每一个节点对所述目标数据进行确认和部署。
9.根据权利要求7所述的分层部署方法,其特征在于,还包括:
在第二层模块将所述目标数据上传至所述第二层模块中的节点对应的第一层模块中的节点的过程中,未收到正确的反馈信息时,通过第二层模块的纠错模块将未收到正确的反馈信息对应的数据重新上传至第二层模块中的节点对应的第一层模块中除故障节点外的所有节点;
在第三层模块将所述目标数据上传至所述第三层模块中的节点对应的第二层模块中的节点的过程中,未收到正确的反馈信息时,通过第三层模块的纠错模块将未收到正确的反馈信息对应的数据重新上传至第三层模块中的节点对应的第二层模块中除故障节点外的所有节点。
10.根据权利要求9所述的分层部署方法,其特征在于,还包括:
通过第二层模块的节点的纠错响应模块在第二层模块中检查目标数据是否正确完成目标操作;其中,所述目标操作包括:部署和/或确认;
若目标数据正确完成目标操作,则反馈正确的反馈信息至第三层模块的纠错模块;
若目标数据未正确完成目标操作,则重新向第一层模块发起上传请求;
通过第一层模块的节点的纠错响应模块检查目标数据是否正确完成目标操作;
若目标数据正确完成目标操作,则反馈正确的反馈信息至第二层模块的纠错模块;
若目标数据未正确完成目标操作,则重新进行所述目标操作。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210211954.1A CN114584474A (zh) | 2022-03-04 | 2022-03-04 | 联盟区块链及分层部署方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210211954.1A CN114584474A (zh) | 2022-03-04 | 2022-03-04 | 联盟区块链及分层部署方法 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN114584474A true CN114584474A (zh) | 2022-06-03 |
Family
ID=81772791
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210211954.1A Pending CN114584474A (zh) | 2022-03-04 | 2022-03-04 | 联盟区块链及分层部署方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114584474A (zh) |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109151013A (zh) * | 2018-08-13 | 2019-01-04 | 南京邮电大学 | 基于联盟区块链的物流业信息平台 |
CN110334525A (zh) * | 2019-05-23 | 2019-10-15 | 积惠多(北京)科技有限公司 | 一种基于区块链多层联盟式账户管理系统及方法 |
WO2020113545A1 (zh) * | 2018-12-07 | 2020-06-11 | 北京大学深圳研究生院 | 基于联盟链投票共识算法产生及管理多模标识网络的方法 |
CN112769580A (zh) * | 2020-12-31 | 2021-05-07 | 阳江市链点创新科技发展有限公司 | 一种区块链分层激励共识算法 |
CN113191772A (zh) * | 2021-04-12 | 2021-07-30 | 西安交通大学 | 一种基于分层模型的联盟链的共识方法 |
-
2022
- 2022-03-04 CN CN202210211954.1A patent/CN114584474A/zh active Pending
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109151013A (zh) * | 2018-08-13 | 2019-01-04 | 南京邮电大学 | 基于联盟区块链的物流业信息平台 |
WO2020113545A1 (zh) * | 2018-12-07 | 2020-06-11 | 北京大学深圳研究生院 | 基于联盟链投票共识算法产生及管理多模标识网络的方法 |
CN110334525A (zh) * | 2019-05-23 | 2019-10-15 | 积惠多(北京)科技有限公司 | 一种基于区块链多层联盟式账户管理系统及方法 |
CN112769580A (zh) * | 2020-12-31 | 2021-05-07 | 阳江市链点创新科技发展有限公司 | 一种区块链分层激励共识算法 |
CN113191772A (zh) * | 2021-04-12 | 2021-07-30 | 西安交通大学 | 一种基于分层模型的联盟链的共识方法 |
Non-Patent Citations (1)
Title |
---|
石文娟;: "区块联盟链下的银行间合作机制研究及实践", 金融电子化, no. 07, 15 July 2019 (2019-07-15) * |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20190289068A1 (en) | Method, apparatus and system for realizing communication between blockchains | |
CN107193490B (zh) | 一种基于区块链的分布式数据存储系统及方法 | |
CN111630826B (zh) | 共识系统和方法 | |
CN109901949B (zh) | 双活数据中心的应用灾备系统及方法 | |
CN110741372A (zh) | 用于管理区块链网络上的交易的计算机实现的系统和方法 | |
CN109547530B (zh) | 区域共识方法、系统及设备 | |
US7603354B2 (en) | Method for enhancing the operation of a database | |
CN111400112B (zh) | 分布式集群的存储系统的写入方法、装置及可读存储介质 | |
CN104008152A (zh) | 支持海量数据访问的分布式文件系统的架构方法 | |
CN108319618B (zh) | 一种分布式存储系统的数据分布控制方法、系统及装置 | |
CN114301972B (zh) | 一种基于云边协同的区块链节点分级部署方法和系统 | |
CN111711526B (zh) | 一种区块链节点的共识方法及系统 | |
CN110458709B (zh) | 资源转移信息的传输方法和装置、存储介质、电子装置 | |
WO2022048357A1 (zh) | 交易背书方法、装置及存储介质 | |
CN114363352B (zh) | 基于区块链的物联网系统跨链交互方法 | |
CN112422341A (zh) | 区块链网络的故障检测方法及相关设备 | |
CN102521073A (zh) | 在故障恢复期间增加数据库的可用性 | |
US20090187600A1 (en) | Method of improving replica server performance and a replica server system | |
CN113326500B (zh) | 结合边缘计算和云边融合的信息验证方法及中心云平台 | |
CN111209542B (zh) | 一种权限管理方法、装置、存储介质及电子设备 | |
CN114584474A (zh) | 联盟区块链及分层部署方法 | |
CN110071966B (zh) | 基于云平台的区块链组网及数据处理方法 | |
US20080250421A1 (en) | Data Processing System And Method | |
CN114584450A (zh) | 双层区块链系统及共识方法 | |
CN116846888A (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 |