CN111475572B - 区块生成方法、装置、设备和介质 - Google Patents
区块生成方法、装置、设备和介质 Download PDFInfo
- Publication number
- CN111475572B CN111475572B CN202010254531.9A CN202010254531A CN111475572B CN 111475572 B CN111475572 B CN 111475572B CN 202010254531 A CN202010254531 A CN 202010254531A CN 111475572 B CN111475572 B CN 111475572B
- Authority
- CN
- China
- Prior art keywords
- parallel
- block
- transaction data
- basic
- current
- 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
- 238000000034 method Methods 0.000 title claims abstract description 59
- 238000012545 processing Methods 0.000 claims abstract description 38
- 238000010276 construction Methods 0.000 claims description 23
- 230000015654 memory Effects 0.000 claims description 22
- 230000008569 process Effects 0.000 claims description 17
- 238000012544 monitoring process Methods 0.000 claims description 6
- 230000007246 mechanism Effects 0.000 claims description 4
- 238000013500 data storage Methods 0.000 abstract description 7
- 238000005516 engineering process Methods 0.000 abstract description 3
- 238000010586 diagram Methods 0.000 description 11
- 230000003993 interaction Effects 0.000 description 8
- 230000003071 parasitic effect Effects 0.000 description 7
- 238000004364 calculation method Methods 0.000 description 4
- 238000004891 communication Methods 0.000 description 4
- 238000004590 computer program Methods 0.000 description 4
- 238000012986 modification Methods 0.000 description 4
- 230000004048 modification Effects 0.000 description 4
- 238000004422 calculation algorithm Methods 0.000 description 3
- 230000006870 function Effects 0.000 description 3
- 239000003999 initiator Substances 0.000 description 2
- 239000004973 liquid crystal related substance Substances 0.000 description 2
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000001413 cellular effect Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 238000010295 mobile communication Methods 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 238000012856 packing Methods 0.000 description 1
- 230000001953 sensory effect Effects 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 238000012795 verification Methods 0.000 description 1
- 230000000007 visual effect Effects 0.000 description 1
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
-
- 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/2228—Indexing structures
- G06F16/2255—Hash tables
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/60—Protecting data
- G06F21/64—Protecting data integrity, e.g. using checksums, certificates or signatures
-
- 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)
- General Physics & Mathematics (AREA)
- Databases & Information Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- Data Mining & Analysis (AREA)
- Software Systems (AREA)
- Computer Security & Cryptography (AREA)
- Computing Systems (AREA)
- Health & Medical Sciences (AREA)
- Bioethics (AREA)
- General Health & Medical Sciences (AREA)
- Computer Hardware Design (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本申请实施例公开了一种区块生成方法、装置、设备和介质,涉及区块链技术。其中,该方法包括:对基础区块链中基础事务请求进行处理,得到基础事务数据,且对平行区块链中平行事务请求进行处理,得到平行事务数据;根据平行事务数据构建当前平行区块;根据基础事务数据、平行事务数据和当前平行区块,构建当前基础区块。本申请实施例可以优化针对多链场景下的区块数据存储方式。
Description
技术领域
本申请实施例涉及计算机技术,具体涉及区块链技术,尤其涉及一种区块生成方法、装置、设备和介质。
背景技术
目前,在区块数据存储方面,通常会针对每一条区块链,分别为其设置独立的数据库,以用于存储区块数据,即各条链的账本和状态都是分离存储的。
然而,随着区块链节点上部署的区块链数量的增加,数据库增多,对区块链节点的存储空间消耗非常大。在存储空间有限的情况下,这也限制了区块链节点上可以部署的区块链数量。
发明内容
本申请实施例公开一种区块生成方法、装置、设备和介质,以优化针对多链场景下的区块数据存储方式。
第一方面,本申请实施例公开了一种区块生成方法,应用于区块链节点,所述区块链节点上部署有基础区块链和平行区块链,所述方法包括:
对所述基础区块链中基础事务请求进行处理,得到基础事务数据,且对所述平行区块链中平行事务请求进行处理,得到平行事务数据;
根据所述平行事务数据构建当前平行区块;
根据所述基础事务数据、所述平行事务数据和所述当前平行区块,构建当前基础区块。
第二方面,本申请实施例公开了一种区块生成装置,配置于区块链节点,所述区块链节点上部署有基础区块链和平行区块链,所述装置包括:
事务数据确定模块,用于对所述基础区块链中基础事务请求进行处理,得到基础事务数据,且对所述平行区块链中平行事务请求进行处理,得到平行事务数据;
平行区块构建模块,用于根据所述平行事务数据构建当前平行区块;
基础区块构建模块,用于根据所述基础事务数据、所述平行事务数据和所述当前平行区块,构建当前基础区块。
第三方面,本申请实施例还公开了一种电子设备,包括:
至少一个处理器;以及
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行如本申请实施例任一所述的区块生成方法。
第四方面,本申请实施例还公开了一种存储有计算机指令的非瞬时计算机可读存储介质,所述计算机指令用于使所述计算机执行如本申请实施例任一所述的区块生成方法。
根据本申请实施例的技术方案,针对区块链节点上同时部署有基础区块链和平行区块链的情况,通过将当前平行区块嵌套在当前基础区块中,优化了针对多链场景下的区块数据存储方式,使得即使区块链节点上部署的区块链数量增加,也无需增加底层数据库的数量,降低了区块链节点上新创建区块链的成本,每个区块链节点上可以部署的区块链数量也可以摆脱存储空间的限制。
应当理解,本部分所描述的内容并非旨在标识本申请的实施例的关键或重要特征,也不用于限制本申请的范围。本申请的其它特征将通过以下的说明书而变得容易理解。
附图说明
附图用于更好地理解本方案,不构成对本申请的限定。其中:
图1是根据本申请实施例公开的一种区块链网络的结构示意图;
图2是根据本申请实施例公开的一种区块生成方法的流程图;
图3是根据本申请实施例公开的一种区块链结构的示意图;
图4是根据本申请实施例公开的另一种区块生成方法的流程图;
图5是根据本申请实施例公开的一种区块的结构示意图;
图6是根据本申请实施例公开的一种区块生成装置的结构示意图;
图7是根据本申请实施例公开的一种电子设备的框图。
具体实施方式
以下结合附图对本申请的示范性实施例做出说明,其中包括本申请实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本申请的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
图1是根据本申请实施例公开的一种区块链网络的结构示意图。图1所示的网络结构仅用于对本申请实施例进行示例性说明,不应理解为对本申请实施例的具体限定。参与区块链网络的节点数量可以根据需求而定。图1作为示例,示出了包括3个区块链节点的一种区块链网络结构示意图。每个区块链节点上可以部署一条基础区块链和至少一条平行区块链。基础区块链也可以称为母区块链或主区块链,平行区块链也可以称为子区块链。基于业务处理需求的划分,基础区块链和平行区块链可以用于处理不同的业务逻辑,本申请实施例对基础区块链和平行区块链的具体划分不作具体限定。并且,针对不同的区块链节点,除了均需要部署基础区块链外,可以根据实际情况选择部署的平行区块链,即每个区块链节点上部署的平行区块链的数量可以相同,也可以不同。
可选的,在本申请实施例中,基础区块链和平行区块链上可以部署相同的共识机制,平行区块链上可以没有独立的共识算法,从而确保同一区块链节点可以同时基于多条链上的事务数据生成区块。
图2是根据本申请实施例公开的一种区块生成方法的流程图,本申请实施例可以适用于当区块链节点上同时部署了多条区块链时,例如同时部署了一条基础区块链和至少一条平行区块链时,如何打包区块的情况。本申请实施例公开的方法可以由区块生成装置来执行,该装置可以采用软件和/或硬件实现,并可以配置于区块链节点中。区块链节点可以部署在任意的具有计算能力的电子设备上。
如图2所示,本申请实施例公开的区块生成方法可以包括:
S101、对基础区块链中基础事务请求进行处理,得到基础事务数据,且对平行区块链中平行事务请求进行处理,得到平行事务数据。
其中,基础事务请求可以是由任意发起方发起的、在基础区块链中传输的任意事务请求,平行事务请求可以是由任意发起方发起的、在平行区块链中传输的任意事务请求。本机节点(即指当前用于执行本申请实施例方法的区块链节点)处理的事务请求的类型包括但不限于基于智能合约的事务请求。当基础区块链和至少一条平行区块链中均存在事务请求时,本机节点需要对这些事务请求均进行处理,得到相应的事务数据。
可选的,对基础区块链中基础事务请求进行处理,得到基础事务数据,且对平行区块链中平行事务请求进行处理,得到平行事务数据,包括:
在对基础区块链中基础事务请求进行处理,得到基础事务数据的过程中,监测本机节点上是否存在平行区块链中的平行事务请求;
如果存在,则对平行区块链中平行事务请求进行处理,得到平行事务数据。即本机节点在执行基础事务请求的过程中,可以利用区块链网络中预先部署的监测程序,对至少一条平行区块链进行监测,以确定至少一条平行区块链中是否存在待处理的平行事务请求,如果当前监测到存在待处理平行事务请求的目标平行区块链,则对该目标平行区块链中的平行事务请求进行处理,得到平行事务数据,从而避免在生成当前区块的过程中,遗漏平行区块链中的事务数据。如果当前未监测到存在待处理平行事务请求的目标平行区块链,则在生成当前区块过程中无需使用平行事务数据。
S102、根据平行事务数据构建当前平行区块。
S103、根据基础事务数据、平行事务数据和当前平行区块,构建当前基础区块。
为了确保每一条链在逻辑上的完整性,以及确保多条链上数据的不可篡改性,本机节点在区块打包过程中,可以首先基于至少一条平行区块链中平行事务请求经处理得到的平行事务数据,生成至少一个当前平行区块,然后将该至少一个当前平行区块用于当前基础区块的生成过程中,从而实现将至少一个当前平行区块置于当前基础区块中的效果。当然,在生成当前平行区块的过程中,也可以灵活选择将当前基础区块的区块高度、平行事务数据的哈希值等与当前平行区块相关的数据用于区块生成过程中,从而进一步确保基础区块和平行区块之间的数据关联性以及数据的不可篡改性。不同的平行区块链对应各自的平行区块。相对于基础区块,平行区块也可以称为子区块、微区块或者附属区块。
需要说明的是,在构建当前基础区块和当前平行区块的过程中,可以利用预先设定的区块生成策略,基于已有的事务数据,通过增加其他相关的区块数据,例如区块高度、时间戳、区块哈希值等,分别完成当前基础区块和当前平行区块的生成。区块生成策略可以用于定义区块生成过程中所需的数据以及区块结构等内容。区块生成过程中所需的数据,可以根据实际情况进行灵活调整。
由于当前平行区块寄生或者嵌套在当前基础区块中,因此,在数据存储层只需要利用一个数据库来存储当前基础区块,即可同时实现对基础区块链和平行区块链中数据的存储。区块链节点上每增加一条平行区块链,只需要在已有数据库中增加一些键值对(Key-Value)存储条目,无需随着链数量的增加而新建数据库,进而可以几乎无成本地创建新的平行区块链。
通常,新建一个数据库,对节点内存和文件句柄开销都较大,例如新的文件夹、文件和数据库实例均需要占用较多内存,采用本申请实施例的技术方案后,可以减少数据库的数量,每个区块链节点上可以部署的区块链数量也由此可以摆脱存储空间的限制,解决了一条链对应一个数据库导致区块链节点存储空间占用严重,进而限制区块链节点上可支持的链数量的问题,每个区块链节点支持的区块链数量越多,也有利于充分利用的处理器的多核计算能力。
同时,通过本申请实施例的技术方案,由于多条区块链的数据均可以存储在一个数据库中,即意味着多条区块链可以共同访问同一数据库,跨链交互操作的原子性实现起来也更加容易,通过数据库的一个批量处理写入就可以完成,不需要像底层存在多个数据库时需要利用哈希时间锁、两阶段提交等复杂的协议来实现,从而解决了一条链对应一个数据库时,跨链数据交互实现难度大、复杂度高的问题。
图3是根据本申请实施例公开的一种区块链结构的示意图。图3作为一种示例,不应理解为对本申请实施例的具体限定。如图3所示,平行区块A1和平行区块C1同时寄生在一个基础区块中,平行区块A2和平行区块C2各自寄生在不同的基础区块中,平行区块A3和平行区块C3同时寄生在另一个基础区块中;多个基础区块可以构成一条基础区块链结构,平行区块A1、A2和A3可以构成一条平行区块链结构,平行区块C1、C2和C3可以构成另一条平行区块链结构。由图3也可以看出,每个基础区块中包括的平行区块的数量可以不同,也即在基础区块链中存在待处理的基础事务请求时,至少一条平行区块链中可以不存在平行事务请求或者部分地存在平行事务请求;利用平行事务数据生成的平行区块需要根据当前基础区块的生成顺序而对应地寄生在当前基础区块中。
图4是根据本申请实施例公开的另一种区块生成方法的流程图,基于上述技术方案进一步优化与扩展,并可以与上述各个可选实施方式进行结合。如图4所示,该方法可以包括:
S201、对基础区块链中基础事务请求进行处理,得到基础事务数据,且对平行区块链中平行事务请求进行处理,得到平行事务数据。
S202、根据平行事务数据构建当前平行区块。
区块包括区块头和区块体,区块头和区块体中包括的数据可以灵活设置。本机节点可以基于平行事务数据,分别构建当前平行区块的区块头和区块体。其中,当前平行区块的区块头中可以包括当前平行区块的梅克尔根(Merkle根)、当前平行区块ID(如哈希值)、上一平行区块的哈希值(PreHash)、当前平行区块高度、和时间戳(Timestamp)等数据中的至少一种;当前平行区块的区块体中可以包括但不限于平行事务数据。如果一个或者多个事务请求形成一个交易,则区块体中可以包括但不限于交易数据等。关于梅克尔根和哈希值的具体计算方式,可以采用现有相关算法实现,本申请实施例不作具体限定。
示例性的,根据平行事务数据构建当前平行区块,包括:
根据平行事务数据,计算当前平行区块的梅克尔根;
根据当前平行区块的梅克尔根、以及上一平行区块的哈希值,构建当前平行区块的区块头,并将平行事务数据作为当前平行区块的区块体。其中,梅克尔根的计算,确保了当前区块体中平行事务数据的不可篡改性,当前平行区块可以通过上一平行区块的哈希值指向上一平行区块,确保了即使平行区块寄生在基础区块中,平行区块链在逻辑上也是独立、完整的链结构。
S203、根据基础事务数据和平行事务数据,构建当前基础区块的区块头。
由于平行区块寄生在基础区块中,为了确保基础区块链和平行区块链中数据的不可篡改性,本申请实施例中同时基于基础事务数据和平行事务数据,构建当前基础区块的区块头。当前基础区块的区块头中可以包括当前基础区块的梅克尔根(Merkle根)、当前基础区块ID(如哈希值)、上一基础区块的哈希值(PreHash)、当前基础区块高度、时间戳(Timestamp)等数据中的至少一种。其中,梅克尔根和哈希值的具体计算方式可以采用现有相关算法实现,本申请实施例不作具体限定。
示例性的,根据基础事务数据和平行事务数据,构建当前基础区块的区块头,包括:
根据基础事务数据和平行事务数据,计算当前基础区块的梅克尔根;
根据当前基础区块的梅克尔根、以及上一基础区块的哈希值,构建当前基础区块的区块头。其中,梅克尔根的计算,确保了当前区块体中基础事务数据和平行事务数据的不可篡改性,当前基础区块可以通过上一基础区块的哈希值指向上一基础区块,确保了基础区块链在逻辑上的完整性。
S204、根据基础事务数据和当前平行区块,构建当前基础区块的区块体。
当前平行区块位于当前基础区块中,因此,本机节点可以在本地利用一个数据库实现对基础区块链和平行区块链中数据的同时存储。此外,操作S203和操作S204之间并无严格的执行顺序限定,不应将图4所示出的逻辑顺序理解为对本申请实施例的具体限定。
图5是根据本申请实施例公开的一种区块的结构示意图,作为一种示例,不应理解为对本申请实施例的具体限定。如图5所示,当前基础区块52包括区块头521和区块体,区块体中包括基础事务数据(或称为交易数据)存储区域522、第一平行区块53和第二平行区块54;第一平行区块53包括区块头531和区块体532,区块体532用于存储该第一平行区块53对应的平行区块链A中平行事务请求经处理得到的平行事务数据;第二平行区块54包括区块头541和区块体542,区块体542用于存储该第二平行区块54对应的平行区块链B中平行事务请求经处理得到的平行事务数据。第一平行区块53和第二平行区块54中的“第一”、“第二”不存在任何顺序上的限定,只用于对不同平行区块的区分命名。
此外,本机节点生成当前基础区块后,可以利用自己的密钥,例如私钥,对该当前基础区块进行签名,然后将签名后的当前基础区块传输至区块链网络,以供其他区块链节点进行验证并存储。由于在本申请实施例中,每个区块链节点上部署的平行区块链可以不相同,因此,当其他区块链节点对本机节点发送的基础区块进行验证时,发现基础区块的区块体中存在自己未参与或不感兴趣的事务数据或交易数据时,可以将这些事务数据或交易数据进行丢弃,即选择性地存储基础区块的区块体中的数据,本申请实施例对此不作具体限定。
根据本申请实施例的技术方案,首先基于平行事务数据构建当前平行区块,然后,根据基础事务数据和平行事务数据,构建当前基础区块的区块头,确保了基础区块链和平行区块链上数据的不可篡改性,并根据基础事务数据和当前平行区块,构建当前基础区块的区块体,实现了将当前平行区块寄生在当前基础区块的区块体中。本申请实施例优化了针对多链场景下的区块数据存储方式,使得即使区块链节点上部署的区块链数量增加,也无需增加底层数据库的数量,可以几乎无成本地创建新的平行区块链,并且,每个区块链节点上可以部署的区块链数量也可以摆脱存储空间的限制,解决了一条链对应一个数据库导致区块链节点存储空间占用严重,进而限制区块链节点上可支持的链数量的问题;同时,通过本申请实施例的技术方案,跨链交互操作的原子性实现起来也更加容易,通过数据库的一个批量处理写入就可以完成,不需要像底层存在多个数据库时需要利用哈希时间锁、两阶段提交等复杂的协议来实现,从而解决了一条链对应一个数据库时,跨链数据交互实现难度大、复杂度高的问题。
图6是根据本申请实施例公开的一种区块生成装置的结构示意图。本申请实施例可以适用于当区块链节点上同时部署了多条区块链时,例如同时部署了一条基础区块链和至少一条平行区块链时,如何打包区块的情况。本申请实施例公开的装置可以采用软件和/或硬件实现,并可以配置于区块链节点中。区块链节点可以部署在任意的具有计算能力的电子设备上。
如图6所示,本申请实施例公开的区块生成装置300可以包括事务数据确定模块301、平行区块构建模块302和基础区块构建模块303,其中:
事务数据确定模块301,用于对基础区块链中基础事务请求进行处理,得到基础事务数据,且对平行区块链中平行事务请求进行处理,得到平行事务数据;
平行区块构建模块302,用于根据平行事务数据构建当前平行区块;
基础区块构建模块303,用于根据基础事务数据、平行事务数据和当前平行区块,构建当前基础区块。
可选的,基础区块构建模块303包括:
区块头构建单元,用于根据基础事务数据和平行事务数据,构建当前基础区块的区块头;
区块体构建单元,用于根据基础事务数据和当前平行区块,构建当前基础区块的区块体。
可选的,区块头构建单元包括:
计算子单元,用于根据基础事务数据和平行事务数据,计算当前基础区块的梅克尔根;
构建子单元,根据当前基础区块的梅克尔根、以及上一基础区块的哈希值,构建当前基础区块的区块头。
可选的,平行区块构建模块302包括:
计算单元,用于根据平行事务数据,计算当前平行区块的梅克尔根;
构建单元,用于根据当前平行区块的梅克尔根、以及上一平行区块的哈希值,构建当前平行区块的区块头,并将平行事务数据作为当前平行区块的区块体。
可选的,事务数据确定模块301包括:
基础事务数据确定单元,用于对基础区块链中基础事务请求进行处理,得到基础事务数据;
监测单元,用于在对基础区块链中基础事务请求进行处理,得到基础事务数据的过程中,监测本机节点上是否存在平行区块链中的平行事务请求;
平行事务数据确定单元,用于如果存在,则对平行区块链中平行事务请求进行处理,得到平行事务数据。
可选的,基础区块链和平行区块链上部署相同的共识机制。
本申请实施例所公开的区块生成装置300可执行本申请实施例所公开的任意区块生成方法,具备执行方法相应的功能模块和有益效果。本申请实施例中未详尽描述的内容可以参考本申请任意方法实施例中的描述。
根据本申请的实施例,本申请实施例还提供了一种电子设备和一种可读存储介质。
如图7所示,图7是用于实现本申请实施例中区块生成方法的电子设备的框图。电子设备旨在表示各种形式的数字计算机,诸如,膝上型计算机、台式计算机、工作台、个人数字助理、服务器、刀片式服务器、大型计算机、和其它适合的计算机。电子设备还可以表示各种形式的移动装置,诸如,个人数字处理、蜂窝电话、智能电话、可穿戴设备和其它类似的计算装置。本文所示的部件、它们的连接和关系、以及它们的功能仅仅作为示例,并且不意在限制本文中描述的和/或者要求的本申请实施例的实现。
如图7所示,该电子设备包括:一个或多个处理器401、存储器402,以及用于连接各部件的接口,包括高速接口和低速接口。各个部件利用不同的总线互相连接,并且可以被安装在公共主板上或者根据需要以其它方式安装。处理器可以对在电子设备内执行的指令进行处理,包括存储在存储器中或者存储器上以在外部输入/输出装置(诸如,耦合至接口的显示设备)上显示图形用户界面(Graphical User Interface,GUI)的图形信息的指令。在其它实施方式中,若需要,可以将多个处理器和/或多条总线与多个存储器和多个存储器一起使用。同样,可以连接多个电子设备,各个设备提供部分必要的操作,例如,作为服务器阵列、一组刀片式服务器、或者多处理器系统。图7中以一个处理器401为例。
存储器402即为本申请实施例所提供的非瞬时计算机可读存储介质。其中,所述存储器存储有可由至少一个处理器执行的指令,以使所述至少一个处理器执行本申请实施例所提供的区块生成方法。本申请实施例的非瞬时计算机可读存储介质存储计算机指令,该计算机指令用于使计算机执行本申请实施例所提供的区块生成方法。
存储器402作为一种非瞬时计算机可读存储介质,可用于存储非瞬时软件程序、非瞬时计算机可执行程序以及模块,如本申请实施例中区块生成方法对应的程序指令/模块,例如,附图6所示的事务数据确定模块301、平行区块构建模块302和基础区块构建模块303。处理器401通过运行存储在存储器402中的非瞬时软件程序、指令以及模块,从而执行电子设备的各种功能应用以及数据处理,即实现上述方法实施例中的区块生成方法。
存储器402可以包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需要的应用程序;存储数据区可存储根据电子设备的使用所创建的数据等。此外,存储器402可以包括高速随机存取存储器,还可以包括非瞬时存储器,例如至少一个磁盘存储器件、闪存器件、或其他非瞬时固态存储器件。在一些实施例中,存储器402可选包括相对于处理器401远程设置的存储器,这些远程存储器可以通过网络连接至用于实现本申请实施例中区块生成方法的电子设备。上述网络的实例包括但不限于互联网、企业内部网、局域网、移动通信网及其组合。
用于实现本申请实施例中区块生成方法的电子设备还可以包括:输入装置403和输出装置404。处理器401、存储器402、输入装置403和输出装置404可以通过总线或者其他方式连接,图7中以通过总线连接为例。
输入装置403可接收输入的数字或字符信息,以及产生与用于实现本申请实施例中区块生成方法的电子设备的用户设置以及功能控制有关的键信号输入,例如触摸屏、小键盘、鼠标、轨迹板、触摸板、指示杆、一个或者多个鼠标按钮、轨迹球、操纵杆等输入装置。输出装置404可以包括显示设备、辅助照明装置和触觉反馈装置等,其中,辅助照明装置例如发光二极管(Light Emitting Diode,LED);触觉反馈装置例如,振动电机等。该显示设备可以包括但不限于,液晶显示器(Liquid Crystal Display,LCD)、LED显示器和等离子体显示器。在一些实施方式中,显示设备可以是触摸屏。
此处描述的系统和技术的各种实施方式可以在数字电子电路系统、集成电路系统、专用集成电路(Application Specific Integrated Circuit,ASIC)、计算机硬件、固件、软件、和/或它们的组合中实现。这些各种实施方式可以包括:实施在一个或者多个计算机程序中,该一个或者多个计算机程序可在包括至少一个可编程处理器的可编程系统上执行和/或解释,该可编程处理器可以是专用或者通用可编程处理器,可以从存储系统、至少一个输入装置、和至少一个输出装置接收数据和指令,并且将数据和指令传输至该存储系统、该至少一个输入装置、和该至少一个输出装置。
这些计算程序,也称作程序、软件、软件应用、或者代码,包括可编程处理器的机器指令,并且可以利用高级过程和/或面向对象的编程语言、和/或汇编/机器语言来实施这些计算程序。如本文使用的,术语“机器可读介质”和“计算机可读介质”指的是用于将机器指令和/或数据提供给可编程处理器的任何计算机程序产品、设备、和/或装置,例如,磁盘、光盘、存储器、可编程逻辑装置(Programmable Logic Device,PLD),包括,接收作为机器可读信号的机器指令的机器可读介质。术语“机器可读信号”指的是用于将机器指令和/或数据提供给可编程处理器的任何信号。
为了提供与用户的交互,可以在计算机上实施此处描述的系统和技术,该计算机具有:用于向用户显示信息的显示装置,例如,阴极射线管(Cathode Ray Tube,CRT)或者LCD监视器;以及键盘和指向装置,例如,鼠标或者轨迹球,用户可以通过该键盘和该指向装置来将输入提供给计算机。其它种类的装置还可以用于提供与用户的交互;例如,提供给用户的反馈可以是任何形式的传感反馈,例如,视觉反馈、听觉反馈、或者触觉反馈;并且可以用任何形式,包括声输入、语音输入或者、触觉输入,来接收来自用户的输入。
可以将此处描述的系统和技术实施在包括后台部件的计算系统,例如,作为数据服务器,或者实施在包括中间件部件的计算系统,例如,应用服务器,或者实施在包括前端部件的计算系统,例如,具有图形用户界面或者网络浏览器的用户计算机,用户可以通过该图形用户界面或者该网络浏览器来与此处描述的系统和技术的实施方式交互,或者实施在包括这种后台部件、中间件部件、或者前端部件的任何组合的计算系统中。可以通过任何形式或者介质的数字数据通信,例如通信网络,来将系统的部件相互连接。通信网络的示例包括:局域网(Local Area Network,LAN)、广域网(Wide Area Network,WAN)、互联网和区块链网络。
计算机系统可以包括客户端和服务器。客户端和服务器一般远离彼此并且通常通过通信网络进行交互。通过在相应的计算机上运行并且彼此具有客户端-服务器关系的计算机程序来产生客户端和服务器的关系。
根据本申请实施例的技术方案,针对区块链节点上同时部署有基础区块链和平行区块链的情况,通过将根据平行事务数据构建当前平行区块,嵌套在根据基础事务数据和平行事务数据构建当前基础区块中,优化了针对多链场景下的区块数据存储方式,使得即使区块链节点上部署的区块链数量增加,也无需增加底层数据库的数量,可以几乎无成本地创建新的平行区块链,并且,每个区块链节点上可以部署的区块链数量也可以摆脱存储空间的限制,解决了一条链对应一个数据库导致区块链节点存储空间占用严重,进而限制区块链节点上可支持的链数量的问题;同时,通过本申请实施例的技术方案,跨链交互操作的原子性实现起来也更加容易,通过数据库的一个批量处理写入就可以完成,不需要像底层存在多个数据库时需要利用哈希时间锁、两阶段提交等复杂的协议来实现,从而解决了一条链对应一个数据库时,跨链数据交互实现难度大、复杂度高的问题。
应该理解,可以使用上面所示的各种形式的流程,重新排序、增加或删除步骤。例如,本申请中记载的各步骤可以并行地执行也可以顺序地执行也可以不同的次序执行,只要能够实现本申请公开的技术方案所期望的结果,本文在此不进行限制。
上述具体实施方式,并不构成对本申请保护范围的限制。本领域技术人员应该明白的是,根据设计要求和其他因素,可以进行各种修改、组合、子组合和替代。任何在本申请的精神和原则之内所作的修改、等同替换和改进等,均应包含在本申请保护范围之内。
Claims (12)
1.一种区块生成方法,其特征在于,应用于区块链节点,所述区块链节点上部署有基础区块链和平行区块链,所述方法包括:
对所述基础区块链中基础事务请求进行处理,得到基础事务数据,且对所述平行区块链中平行事务请求进行处理,得到平行事务数据;
根据所述平行事务数据构建当前平行区块;
根据所述基础事务数据、所述平行事务数据和所述当前平行区块,构建当前基础区块;
其中,根据所述基础事务数据、所述平行事务数据和所述当前平行区块,构建当前基础区块,包括:
根据所述基础事务数据和所述平行事务数据,构建所述当前基础区块的区块头;
根据所述基础事务数据和所述当前平行区块,构建所述当前基础区块的区块体。
2.根据权利要求1所述的方法,其特征在于,根据所述基础事务数据和所述平行事务数据,构建所述当前基础区块的区块头,包括:
根据所述基础事务数据和所述平行事务数据,计算所述当前基础区块的梅克尔根;
根据所述当前基础区块的梅克尔根、以及上一基础区块的哈希值,构建所述当前基础区块的区块头。
3.根据权利要求1所述的方法,其特征在于,根据所述平行事务数据构建当前平行区块,包括:
根据所述平行事务数据,计算所述当前平行区块的梅克尔根;
根据所述当前平行区块的梅克尔根、以及上一平行区块的哈希值,构建所述当前平行区块的区块头,并将所述平行事务数据作为所述当前平行区块的区块体。
4.根据权利要求1所述的方法,其特征在于,对所述基础区块链中基础事务请求进行处理,得到基础事务数据,且对所述平行区块链中平行事务请求进行处理,得到平行事务数据,包括:
在对所述基础区块链中基础事务请求进行处理,得到基础事务数据的过程中,监测本机节点上是否存在所述平行区块链中的平行事务请求;
如果存在,则对所述平行区块链中平行事务请求进行处理,得到所述平行事务数据。
5.根据权利要求1所述的方法,其特征在于,所述基础区块链和所述平行区块链上部署相同的共识机制。
6.一种区块生成装置,其特征在于,配置于区块链节点,所述区块链节点上部署有基础区块链和平行区块链,所述装置包括:
事务数据确定模块,用于对所述基础区块链中基础事务请求进行处理,得到基础事务数据,且对所述平行区块链中平行事务请求进行处理,得到平行事务数据;
平行区块构建模块,用于根据所述平行事务数据构建当前平行区块;
基础区块构建模块,用于根据所述基础事务数据、所述平行事务数据和所述当前平行区块,构建当前基础区块;
其中,所述基础区块构建模块包括:
区块头构建单元,用于根据所述基础事务数据和所述平行事务数据,构建所述当前基础区块的区块头;
区块体构建单元,用于根据所述基础事务数据和所述当前平行区块,构建所述当前基础区块的区块体。
7.根据权利要求6所述的装置,其特征在于,所述区块头构建单元包括:
计算子单元,用于根据所述基础事务数据和所述平行事务数据,计算所述当前基础区块的梅克尔根;
构建子单元,根据所述当前基础区块的梅克尔根、以及上一基础区块的哈希值,构建所述当前基础区块的区块头。
8.根据权利要求6所述的装置,其特征在于,所述平行区块构建模块包括:
计算单元,用于根据所述平行事务数据,计算所述当前平行区块的梅克尔根;
构建单元,用于根据所述当前平行区块的梅克尔根、以及上一平行区块的哈希值,构建所述当前平行区块的区块头,并将所述平行事务数据作为所述当前平行区块的区块体。
9.根据权利要求6所述的装置,其特征在于,所述事务数据确定模块包括:
基础事务数据确定单元,用于对所述基础区块链中基础事务请求进行处理,得到所述基础事务数据;
监测单元,用于在对所述基础区块链中基础事务请求进行处理,得到基础事务数据的过程中,监测本机节点上是否存在所述平行区块链中的平行事务请求;
平行事务数据确定单元,用于如果存在,则对所述平行区块链中平行事务请求进行处理,得到所述平行事务数据。
10.根据权利要求6所述的装置,其特征在于,所述基础区块链和所述平行区块链上部署相同的共识机制。
11.一种电子设备,其特征在于,包括:
至少一个处理器;以及
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行权利要求1-5中任一项所述的区块生成方法。
12.一种存储有计算机指令的非瞬时计算机可读存储介质,其特征在于,所述计算机指令用于使所述计算机执行权利要求1-5中任一项所述的区块生成方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010254531.9A CN111475572B (zh) | 2020-04-02 | 2020-04-02 | 区块生成方法、装置、设备和介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010254531.9A CN111475572B (zh) | 2020-04-02 | 2020-04-02 | 区块生成方法、装置、设备和介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN111475572A CN111475572A (zh) | 2020-07-31 |
CN111475572B true CN111475572B (zh) | 2023-08-29 |
Family
ID=71749855
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010254531.9A Active CN111475572B (zh) | 2020-04-02 | 2020-04-02 | 区块生成方法、装置、设备和介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN111475572B (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP3668036A1 (de) * | 2018-12-14 | 2020-06-17 | Siemens Aktiengesellschaft | Erstellen einer blockchain mit blöcken umfassend eine anpassbare anzahl an transaktionsblöcken und mehrere zwischenblöcke |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107909369A (zh) * | 2017-10-13 | 2018-04-13 | 布比(北京)网络技术有限公司 | 基于跨链交易的共识方法、装置和存储介质 |
WO2018076760A1 (zh) * | 2016-10-27 | 2018-05-03 | 上海亿账通区块链科技有限公司 | 基于区块链的交易事务处理方法、系统、电子装置及存储介质 |
CN108959621A (zh) * | 2018-07-18 | 2018-12-07 | 百度在线网络技术(北京)有限公司 | 一种区块链网络的实现方法、装置、设备及存储介质 |
CN108985774A (zh) * | 2018-07-18 | 2018-12-11 | 百度在线网络技术(北京)有限公司 | 一种区块链网络的激励方法、装置、设备及存储介质 |
CN109858285A (zh) * | 2018-12-07 | 2019-06-07 | 上海异势信息科技有限公司 | 区块链数据的处理方法、装置、设备和介质 |
CN110516006A (zh) * | 2019-08-26 | 2019-11-29 | 杭州复杂美科技有限公司 | 平行链区块生成方法、设备和存储介质 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2019055585A1 (en) * | 2017-09-12 | 2019-03-21 | Kadena Llc | PARALLEL CHAIN ARCHITECTURE FOR BLOCK CHAIN SYSTEMS |
-
2020
- 2020-04-02 CN CN202010254531.9A patent/CN111475572B/zh active Active
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2018076760A1 (zh) * | 2016-10-27 | 2018-05-03 | 上海亿账通区块链科技有限公司 | 基于区块链的交易事务处理方法、系统、电子装置及存储介质 |
CN107909369A (zh) * | 2017-10-13 | 2018-04-13 | 布比(北京)网络技术有限公司 | 基于跨链交易的共识方法、装置和存储介质 |
CN108959621A (zh) * | 2018-07-18 | 2018-12-07 | 百度在线网络技术(北京)有限公司 | 一种区块链网络的实现方法、装置、设备及存储介质 |
CN108985774A (zh) * | 2018-07-18 | 2018-12-11 | 百度在线网络技术(北京)有限公司 | 一种区块链网络的激励方法、装置、设备及存储介质 |
CN109858285A (zh) * | 2018-12-07 | 2019-06-07 | 上海异势信息科技有限公司 | 区块链数据的处理方法、装置、设备和介质 |
CN110516006A (zh) * | 2019-08-26 | 2019-11-29 | 杭州复杂美科技有限公司 | 平行链区块生成方法、设备和存储介质 |
Non-Patent Citations (1)
Title |
---|
小艺."其实你需要的不是公链,而是平行链 ".《中国贸易新闻网》.2018,第1-2页. * |
Also Published As
Publication number | Publication date |
---|---|
CN111475572A (zh) | 2020-07-31 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN111368326B (zh) | 车辆数据处理方法、装置、电子设备和存储介质 | |
JP2022008781A (ja) | 分散型トレーニング方法、システム、デバイス、記憶媒体、及びプログラム | |
US20210108931A1 (en) | Method and apparatus for determining hybrid travel route, device and storage medium | |
CN111277647B (zh) | 区块链网络成员管理方法、装置、设备和介质 | |
CN111782365B (zh) | 定时任务处理方法、装置、设备及存储介质 | |
US20210209417A1 (en) | Method and apparatus for generating shared encoder | |
EP3832493B1 (en) | Method, apparatus, electronic device and readable storage medium for data query | |
EP3869339B1 (en) | Data storage method and apparatus for blockchain, device, and medium | |
EP3832574A2 (en) | Method and apparatus for processing transaction requests in blockchain, device and medium | |
US11349638B2 (en) | Privacy transaction processing method, electronic device and storage medium | |
EP3848816A1 (en) | Method, apparatus, and storage medium for storing determinant text | |
CN111475262A (zh) | 区块链中事务请求处理方法、装置、设备和介质 | |
CN111258957B (zh) | 分布式文件系统目录更新方法、装置、设备和介质 | |
KR20210125893A (ko) | 블록 체인에서의 업무 청구 처리 방법, 장치, 기기, 매체 및 프로그램 | |
EP3869377A1 (en) | Method and apparatus for data processing based on smart contract, device and storage medium | |
CN112380184A (zh) | 事务处理方法、装置、电子设备及可读存储介质 | |
EP3825865A2 (en) | Method and apparatus for processing data | |
CN111581049B (zh) | 分布式系统运行状态监测方法、装置、设备及存储介质 | |
CN111352706B (zh) | 一种数据访问方法、装置、设备及存储介质 | |
CN111475572B (zh) | 区块生成方法、装置、设备和介质 | |
CN104580428A (zh) | 一种数据路由方法、数据管理装置和分布式存储系统 | |
CN111625949A (zh) | 一种仿真引擎系统、仿真处理方法、设备和介质 | |
US20230394483A1 (en) | Blockchain-based data processing method and apparatus | |
CN111737534B (zh) | 文件处理方法、装置及设备 | |
CN111767149B (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 |