CN111756550B - 一种区块链共识方法及装置 - Google Patents
一种区块链共识方法及装置 Download PDFInfo
- Publication number
- CN111756550B CN111756550B CN202010594039.6A CN202010594039A CN111756550B CN 111756550 B CN111756550 B CN 111756550B CN 202010594039 A CN202010594039 A CN 202010594039A CN 111756550 B CN111756550 B CN 111756550B
- Authority
- CN
- China
- Prior art keywords
- service data
- time
- consensus
- service
- 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
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/32—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
- H04L9/3297—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials involving time stamps, e.g. generation of time stamps
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/32—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
- H04L9/3247—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials involving digital signatures
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5005—Allocation of resources, e.g. of the central processing unit [CPU] to service a request
- G06F9/5027—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
- G06F9/5038—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals considering the execution order of a plurality of tasks, e.g. taking priority or time dependency constraints into consideration
-
- 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/04—Payment circuits
- G06Q20/06—Private payment circuits, e.g. involving electronic currency used among participants of a common payment scheme
- G06Q20/065—Private payment circuits, e.g. involving electronic currency used among participants of a common payment scheme using e-cash
-
- 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
- G06Q20/3825—Use of electronic signatures
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/04—Network architectures or network communication protocols for network security for providing a confidential data exchange among entities communicating through data packet networks
- H04L63/0428—Network architectures or network communication protocols for network security for providing a confidential data exchange among entities communicating through data packet networks wherein the data content is protected, e.g. by encrypting or encapsulating the payload
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
- H04L67/1097—Protocols in which an application is distributed across nodes in the network for distributed storage of data in networks, e.g. transport arrangements for network file system [NFS], storage area networks [SAN] or network attached storage [NAS]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/06—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols the encryption apparatus using shift registers or memories for block-wise or stream coding, e.g. DES systems or RC4; Hash functions; Pseudorandom sequence generators
- H04L9/0618—Block ciphers, i.e. encrypting groups of characters of a plain text message using fixed encryption transformation
- H04L9/0637—Modes of operation, e.g. cipher block chaining [CBC], electronic codebook [ECB] or Galois/counter mode [GCM]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/30—Public key, i.e. encryption algorithm being computationally infeasible to invert or user's encryption keys not requiring secrecy
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/54—Interprogram communication
- G06F9/542—Event management; Broadcasting; Multicasting; Notifications
-
- 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
- G06Q2220/00—Business processing using cryptography
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L2209/00—Additional information or applications relating to cryptographic mechanisms or cryptographic arrangements for secret or secure communication H04L9/00
- H04L2209/56—Financial cryptography, e.g. electronic payment or e-cash
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/32—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
- H04L9/3236—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials using cryptographic hash functions
- H04L9/3239—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials using cryptographic hash functions involving non-keyed hash functions, e.g. modification detection codes [MDCs], MD5, SHA or RIPEMD
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/50—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols using hash chains, e.g. blockchains or hash trees
Abstract
本申请公开了一种区块链共识方法及装置,包括:区块链中的节点在接收到业务数据时,确定该业务数据的受理时间,之后存储携带了该受理时间的所述业务数据,以便当需要对业务数据进行共识时,可根据该受理时间,选择进行共识的业务数据,并对选择的业务数据进行共识。可见通过本申请提供的方法,选择待共识的业务数据不再依赖于业务数据中某项属性对应的数值的大小,而是依据受理该业务数据的节点在受理该业务数据时的受理时间选择待共识的业务数据,这样有效保证各业务数据等待共识的时间相对均衡,避免了现有技术中有些业务数据等待共识的时间较长的问题,有效提升了业务数据的处理效率,提高了区块链的运行性能。
Description
本申请是中国专利申请CN 107450979A的分案申请,原申请的申请日为:2017年3月28日;申请号为:201710191996.2;发明创造名称为:一种区块链共识方法及装置。
技术领域
本申请涉及信息技术领域,尤其涉及一种区块链共识方法及装置。
背景技术
随着信息技术的发展,区块链技术由于其具有的开放性、不可篡改性、去中心化等优点,成为人们重点关注的技术。由于现有区块链技术的去中心化的特点,使得在该区块链中执行的业务在存储在区块链(即,上链)之前,还需要由该区块链中的各节点对该业务对应的业务数据(如,对业务进行处理后的结果)进行共识。
而由于通常区块链中的区块容量有限(如,事先约定的容量),但是节点中等待进行共识的业务数据所占用的空间有可能大于该区块容量,所以在现有技术中发起共识的节点还需要从存储的各业务数据中选择出部分业务数据,以对选择的业务数据进行共识。
通常节点根据业务数据中某一属性的数据(例如交易数据)对应的数值(例如交易金额)的多少,选择进行共识的业务数据。
具体的,该区块链中的每个节点,根据该节点存储的各业务数据的指定属性对应的数值(如交易金额),按照数值从大到小的顺序排列,确定一个由各业务数据组成的待共识列表。区块链中的各节点可以按照该节点内存储的该待共识列表中各业务数据的排列顺序,选择业务数据作为需要进行共识的业务数据,以完成对选择的各业务数据的共识。
但是,上述方法存在以下缺陷:由于该待共识列表中各待共识业务的排列顺序是以业务数据中指定属性对应的数值的多少确定的,那么对于数值较小的业务数据,等待共识的时间较长,导致其处理效率比较低。
发明内容
本申请实施例提供一种区块链共识方法,用于解决现有的区块链共识方法中有些业务数据等待共识的时间较长,导致其处理效率比较低的问题。
本申请实施例提供一种区块链共识装置,用于解决现有的区块链共识方法有些业务数据等待共识的时间较长,导致其处理效率比较低的问题。
本申请实施例提供了一种区块链共识方法,包括:
区块链中的节点接收业务数据,确定所述业务数据的受理时间;
所述节点存储携带所述受理时间的所述业务数据;
当需要对业务数据进行共识时,所述节点根据所述受理时间,选择待共识的业务数据,并对选择的所述待共识的业务数据进行共识。
本申请实施例提供了一种区块链共识装置,包括:
确定模块,接收业务数据,确定所述业务数据的受理时间;
存储模块,存储携带所述受理时间的所述业务数据;
选择模块,当需要对业务数据进行共识时,根据所述受理时间,选择待共识的业务数据;
共识模块,对选择的所述待共识的业务数据进行共识。
本申请实施例采用的上述至少一个技术方案能够达到以下有益效果:
首先,区块链中的节点在接收到业务数据时,确定该业务数据的受理时间,之后存储携带了该受理时间的所述业务数据,以便当需要对业务数据进行共识时,可根据该受理时间,选择进行共识的业务数据,并对选择的业务数据进行共识。可见通过本申请提供的方法,选择待共识的业务数据不再依赖于业务数据中某项属性对应的数值的大小,而是依据受理该业务数据的节点在受理该业务数据时的受理时间选择待共识的业务数据,这样有效保证各业务数据等待共识的时间相对均衡,避免了现有技术中有些业务数据等待共识的时间较长的问题,有效提升了业务数据的处理效率,提高了区块链的运行性能。
附图说明
此处所说明的附图用来提供对本申请的进一步理解,构成本申请的一部分,本申请的示意性实施例及其说明用于解释本申请,并不构成对本申请的不当限定。在附图中:
图1为本申请实施例提供的一种区块链共识过程;
图2为本申请实施例提供的一种区块链共识装置的结构示意图。
具体实施方式
为使本申请的目的、技术方案和优点更加清楚,下面将结合本申请具体实施例及相应的附图对本申请技术方案进行清楚、完整地描述。显然,所描述的实施例仅是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。
在现有区块链技术中,区块链中的数据是由该区块链网络中的各区块链节点(以后简称节点)共同维护的。节点在接收到业务请求时,一般需要经过缓存、共识和存储这三个环节方可将业务请求对应的业务数据存储至区块中,并将该区块上链至节点对应的区块链上。当该区块链网络中的多数节点存储该业务数据在各自节点的区块链数据中时,该业务数据才可视为是被存储在了各节点共同维护的区块链数据中。
共识作为必不可少的环节,目前采用的共识机制有工作量证明(POW)机制、拜占庭容错(PBFT)机制、权益机制证明等多种。这里以工作量证明机制为例进行说明。
具体的,首先,节点可接收用户发送的业务请求,该业务请求中包含业务数据,其中,该业务请求可以是用户直接输入该节点的,也可接收区块链网络中其他节点广播的业务请求。具体该节点如何接收该业务请求对业务的执行并不造成影响。
之后,该节点可根据该业务请求确定对应的业务数据。其中,该节点根据该业务请求确定对应的业务数据的过程可称为节点受理业务请求,至于如何确定该业务数据可能随着具体情况的不同而不同。如常见的业务请求中携带的业务数据已经包含了业务需要执行的内容。例如,对于交易业务请求,该交易业务请求中携带有支付方地址,支付方余额,支付金额,收款方地址等信息,则接收该业务请求的节点可直接根据该业务请求确定该业务数据。又如,由于通常业务请求中还可包含针对智能合约的指令等业务数据。这样,该节点在受理该业务请求时,根据业务请求中的业务数据的不同可能还需要根据业务数据进行业务处理,并得到业务处理的结果,则节点在确定业务数据时,也可将该业务处理的结果作为该业务数据。当然,该节点也可将该业务请求中携带的业务数据以及进行业务处理的结果一并作为该业务请求对应的业务数据。具体的该业务数据的内容可根据区块链的配置而不同,只要是与该业务请求对应的,需要存储在该区块链数据中的数据即可视为是业务数据。
需要说明的是,区块链网络中的节点针对一个业务请求可以分为受理节点和非受理节点,这里的受理节点是指接收用户或者其他设备发送该业务请求的节点,非受理节点是指通过广播方式从其他节点获取该业务请求的节点。
当确定的该业务数据没有被存储在已经经过共识的区块链数据中时,该业务数据为待共识的业务数据,并可以被存储在该节点的缓存中。
然后,在该节点确定该待共识的业务数据之后,该节点可将该待共识的业务数据向该区块链网络中的其他节点进行广播,也就是同步至该区块链网络中的其他节点中。这样,该区块链网络中的各节点可以接收通过广播的方式发送的该待共识的业务数据。在后续进行共识时,该区块链网络中的各节点可以对该待共识的业务数据进行共识。
最后,该区块链网络中的各节点可以根据该区块链的共识机制,确定发起共识的节点,并由该发起共识的节点从该节点存储的各待共识的业务数据中,选择用于共识的业务数据。进而由该区块链网络中的各节点可根据该区块链的共识机制,对该发起共识的节点选择的用于共识的业务数据进行共识。
其中,该区块链网络中的每个节点在对该发起共识的节点发送的各待共识的业务数据进行共识时,可判断接收到的各待共识的业务数据,是否也均存储在在该节点缓存中的待共识列表中,若是,则确定接收到的各待共识业务共识通过,并将记录各待共识的业务数据的新区块存储在该节点维护的区块链数据中,若否,则不存储。
以下结合附图,详细说明本申请各实施例提供的技术方案。
图1为本申请实施例提供的一种区块链共识的过程,具体可包括以下步骤:
S101:区块链中的节点接收业务数据,确定所述业务数据的受理时间。
在区块链网络中,通常存在两种类型的节点,一种节点是业务节点,通常业务节点用于发起业务请求,并且不是必要存在的节点。在该业务节点中可不存储完整的区块链数据,视区块链网络的构建情况决定。有些区块链网络中也可能不存在业务节点这种类型的节点。另一种节点是共识节点,通常共识节点为区块链网络中的必要节点,用于接收业务请求,并根据该区块链的共识机制,发起共识或者接收其他共识节点发送的共识提议。经过共识的业务数据将被存储在区块链的区块中。本申请实施例中所记载的节点可以视为是区块链网络中的共识节点,该节点可以接收业务请求,并根据该业务请求确定接收到的业务数据。
具体的,该节点可以是终端,如,手机、个人电脑/平板电脑等设备,或者该节点也可以是服务器,该服务器可以是单独的一台设备,也可以是有多台设备组成的系统,只要该设备作为该区块链网络的节点可接收业务请求,可发起共识即可,本申请对此并不做具体限定。
另外,在现有技术中,通常区块链中的业务请求包含但不限于如表1所示的业务数据。
表1
当然,表1所示了业务请求中业务数据可能包含的业务属性以及对应的内容,也就是说业务数据中还包含其他内容,这里不做具体限定。其中,以版本属性为例说明,该版本属性对应的内容既可以是在业务请求中携带的(也就是发送该业务请求的客户端或者节点写入的),也可以是后续对该业务请求进行业务处理过程中由该节点确定,并加入该业务数据对应的该版本属性中的。又如,业务对应的区块标识所对应的内容,可以是由该节点在确定可将该业务请求对应的业务数据存储在该区块链的新区块中时,确定该新区块的哈希值,而在该节点接收到该业务请求时,该项属性的内容可以是空的,具体内容可等待该节点写入。
另外,该业务标识,可以是该业务内容的摘要,也可以是该业务发起方确定的在该区块链中全局唯一的标识,也可以是该节点在受理该业务请求时确定的该业务数据的标识。具体的,该业务标识如何确定可采用与现有技术相同的方法,本申请对此并不做限定,只要可以在该区块链数据中唯一的确定该业务数据即可。
进一步地,在本申请实施例中,当该节点接收了该业务请求之后,便可根据该业务请求,确定该业务请求对应的业务数据(即,受理该业务请求),以便在后续在对选择进行共识的待共识的业务数据时,可确定是否将该业务数据作为待共识的业务数据存储在该区块链数据的新区块中(即,是否上链)。
更进一步地,为了使该业务数据在后续进行共识时,避免由于该业务数据中的某些属性的资源量的多少,而影响发起共识的节点选择该业务数据进行共识。在本申请实施例中,该节点在受理该业务请求(如,确定该与该业务请求对应的待共识的业务数据)时,可确定该节点本地的时间戳,并作为该待共识的业务数据的受理时间。
由于对于一个业务请求来说,受理该业务请求的节点通常仅存在一个,所以该节点在受理该业务请求确定对应的待共识的业务数据的受理时间在该区块链数据中也是唯一的,并且,该受理时间不会因该业务请求对应的该业务数据内容的不同而不同。另外,由于该受理时间是受理该业务请求的节点在受理时确定的,所以也使得通过广播方式接收到该待共识的业务数据的其他节点,不会因为接收该待共识的业务数据的时间的不同而在共识时确定不同的选择结果,使得该待共识的业务数据的受理时间戳受的影响(如,业务内容,网络延时)较少。
当然,在本申请实施例中,该节点也可以将该节点接收该业务请求时,该节点本地时间对应的时间戳,作为该业务请求对应的业务数据的受理时间。或者,该节点也可以以其他方式确定该业务数据的时间戳(例如:在接收到所述业务数据时,对所述业务数据进行处理,得到处理结果,将所述处理结果的生成时间确定为所述业务数据的受理时间),只要该业务数据的时间戳为接收该业务请求的节点确定的即可,也就是说,在该区块链数据中该业务数据的时间戳,可只由一个节点来确定。
另外,正如前述的,对于不同的区块链或者不同的业务请求来说,由于该业务请求对应的业务数据中可能还携带有针对智能合约的操作指令等数据,所以该节点有可能还需要根据该业务数据进行业务处理,并且得到业务处理结果,则该业务受理时间还可以是,该节点根据该业务请求(或者,该业务请求中的业务数据)进行业务处理之后得到业务处理结果时,该节点本地时间戳。
进一步地,若该节点确定的该受理时间的精度较低,如,秒级的时间精度,则当该节点在1秒内受理了多个业务请求时,则在这1秒内受理的该多个业务请求分别对应的各业务数据的受理时间相同,则可能导致后续选择待共识的业务数据时出现难以选择的问题,所以为了减少出现多个业务数据的受理时间相同的概率,在本申请实施例中,该受理时间的精度可以设置的较高例如,以毫秒精度确定该受理时间,具体可根据实际应用的需要由工作人员设置,如,在该区块链网络中的各节点平均每分钟接收一个业务请求,那么该受理时间的时间精度就可以设置的较低。
S102:所述节点存储携带所述受理时间的所述业务数据。
在本申请实施例中,当该节点确定该业务数据的受理时间之后,便可将携带有该受理时间的业务数据进行存储,例如:将携带有该受理时间的业务数据存储在该节点本地缓存中,以便后续需要进行共识时,可对该业务数据进行共识。
具体的,该节点可将在步骤S101中确定的该业务数据的受理时间加入该业务数据中,若该业务数据的各属性中已经有时间戳属性,并且该时间戳属性的内容为空时,则将确定的该业务数据的受理时间写入该时间戳属性中。当然若该业务数据原有的时间戳属性中已经写入数据,或者该业务数据中没有时间戳属性,则该节点可以为该业务数据添加新的“受理时间”属性,并将在步骤S101中确定的该业务数据的受理时间写入该“受理时间”属性中。
也就是说,在本申请实施例中,该节点在将该受理时间戳携带在该业务数据中时,该节点可以为该业务数据增加受理时间属性,并将该业务数据的受理时间的数值,作为该受理时间属性的内容,以使得该业务数据携带该受理时间。例如,以表1所示的业务数据为例,该节点可将该业务数据更新为表2所示的业务数据。
表2
当然,正如本申请实施例中在步骤S101中所述的,该受理时间也可是以该节点进行业务处理之后,确定业务处理结果的时间,所以该节点在执行本申请中步骤S102之前,还可以根据实际应用的情况,通过该业务请求和/或该业务数据,进行业务处理的操作。由于进行业务处理已经是现有区块链技术中节点处理业务的方法,所以本申请对此不再赘述。
进一步地,该节点还可以将携带有受理时间的业务数据存储在该节点的缓存中,以等待共识。
具体的,该节点在存储携带受理时间的该业务数据时,可以是将该携带受理时间的业务数据存储在该节点缓存中的待共识业务数据池中,或者以列表的形式,存储在该节点的缓存中,具体采用哪种形式进行存储本申请不做限定。
S103:当需要对业务数据进行共识时,所述节点根据所述受理时间,选择待共识的业务数据,并对选择的所述待共识的业务数据进行共识。
在本申请实施例中,一旦确定需要对业务数据进行共识,不管采用什么共识机制,区块链中的各节点统一按照业务数据的受理时间,选择待共识的业务数据,这样能够保证在进行共识时,所使用的业务数据是相同。
需要说明的是,本申请实施例中所记载的受理时间可以理解为时间戳,这个时间戳可以是节点受理业务请求时为该业务请求生成的时间戳,也可以是节点在接收到的业务请求时对业务请求进行处理之后生成的时间戳,这里不做具体限定。
节点可根据存储的各业务数据的受理时间的时间先后顺序,选择进行共识的待共识的业务数据。
具体的,该节点的缓存中可存储有多个业务数据,包括该节点通过接收业务请求确定的业务数据,以及该节点通过广播接收的由该区块链网络中其他节点同步至该节点的业务数据(即,其他节点确定的待共识业务)。其中,由该节点确定的业务数据的受理时间,是该节点确定该业务数据的受理时间,由其他节点确定的业务数据的受理时间,不是该节点确定,而是由受理该业务数据对应的业务请求的其他节点确定的。
由于该节点中存储的各业务数据均携带有对应的受理时间,并且各业务数据的受理时间通常不同,所以在本申请实施例中,首先,该节点可以根据各业务数据的受理时间,按照时间先后顺序,对各业务数据进行排序。
其次,该节点可根据该区块链的共识机制,确定新区块的区块容量,进而根据该区块容量,确定该新区块可记录的业务数据的数量。通常,为了减少区块链数据上记录数据的占用的存储空间,该业务数据在记录至该区块中时,是先计算该业务数据的摘要,并将该业务数据的摘要记录在该区块中,所以该节点在确定业务数据的数量时,可以是根据业务数据的摘要的占用空间大小以及该区块容量,确定可记录的业务数据的数量,当然,具体该节点如何确定可记录的业务数据的数量本申请不做限定,可根据实际应用的需要,通过对共识机制的配置来确定。
再次,该节点可根据确定进行共识的业务数据的数量,按照各业务数据的排序后的先后顺序,选择该数量的业务数据,作为待共识的业务数据。
由于对于该区块链网络中的每个节点,同一个待共识的业务数据的时间戳是相同的,所以在该区块链网络中不同节点若在同一时间确定的待共识的业务数据的排列顺序也是相同的,从而使得该区块链网络中的不同节点若在同一时间发起共识,不同节点选择的待共识的业务数据相同的几率也较高。
例如,假设对于区块链网络中的节点A,该节点A缓存中存储的各业务数据如表3所示。
业务数据的标识 | 受理时间的时间戳 |
业务1 | 100 |
业务2 | 99 |
业务3 | 102 |
业务4 | 70 |
表3
其中,该业务1以及该业务3为该节点A通过受理业务请求确定的业务数据,该业务2为节点B发送至该节点A的业务数据,该业务4位节点C发送至该节点A的业务数据。
则该节点A可根据各业务数据的受理时间,按照时间先后顺序,对各业务数据进行排序,并可确定如表4所示的列表排序。
表4
之后,该节点A便可根据共识机制确定需要进行共识的业务数量,假设该数量为2,则该节点A可将选择该业务4以及该业务2作为待共识的业务数据。
当然,该节点也可以不对存储的各业务数据按照受理时间的时间先后顺序进行排序,而是通过遍历各业务数据的受理时间,之后按照受理时间的时间先后顺序选择进行共识的业务数据。具体的,该节点如何根据各业务数据的受理时间,按照时间先后顺序,选择进行共识的业务数据,本申请并不限定。只要该节点选择的各待共识的业务数据是按照各业务数据的受理时间的时间先后顺序选择的即可,也就是说,达到先受理的业务数据先进行共识的结果即可。
通过如图1所示的区块链共识过程,该区块链网络中的节点,在接收到接收业务数据时,通过确定该业务数据的受理,并存储携带该受理时间的该业务数据,当需要对业务数据进行共识时,可以根据各业务数据的受理时间,确定各业务数据的受理时间的先后顺序,并以先受理先共识的原则,按顺序选择满足待存储的区块的区块容量的待共识的业务数据进行共识。使得即使是由其他节点发送来的业务数据,由于该业务数据的受理时间是接收该业务数据的节点受理该业务数据的时间戳,那么该区块链网络中的各节点所记录的该业务数据的受理时间戳是相同的,这样先受理的业务请求在区块链网络中将会被先进行共识,有效保证了业务数据等待共识时间相对均衡,相对现有技术,避免了现有技术中有些业务数据等待共识的时间较长的问题,有效提升了业务数据的处理效率,提高了区块链的运行性能。
另外,在本申请实施例步骤S102中,该节点在存储该业务数据时,便可以根据该业务数据的受理时间,按照时间先后顺序将该业务数据存储在缓存中,则该节点的缓存中可配置有业务数据列表,该列表中的业务数据均是按照受理时间的先后顺序排序的。则在步骤S103中,当需要进行业务数据共识时,仅需确定进行共识的业务数量,并从该业务数据列表中按顺序选择该业务数量的业务数据,作为该待共识的业务数据即可。
进一步地,在本申请实施例中,该节点在接收到该区块链网络中的其他节点广播的业务数据时,可以先判断该节点存储的各业务数据中是否已经存在相同的业务数据,若是,则不将该业务数据存储在该节点中(即,避免存储两个相同的待共识业务),若否,则将该业务数据存储在该节点的本地缓存中。
更进一步地,若该节点中存在按照时间先后顺序排序的业务数据列表,则该节点在确定存储该业务数据时,可根据该业务数据的受理时间,按照时间先后顺序,将接收的该业务数据加入该节点的业务数据列表中。
例如,假设如表4所述的业务数据列表,为节点A存储的业务数据。当该节点A接收到该节点B发送的业务数据为:业务5,并且该业务5的受理时间为10时,该节点A可按受理时间的时间先后顺序将该业务5插入该业务数据列表中,如表5所示。
业务数据的标识 | 受理时间的时间戳 |
业务5 | 10 |
业务4 | 70 |
业务2 | 99 |
业务1 | 100 |
业务3 | 102 |
表5
需要说明的是,本申请实施例所提供方法的各步骤的执行主体均可以是同一设备,或者,该方法也由不同设备作为执行主体。比如,步骤S101和步骤S102的执行主体可以为设备1,步骤S103的执行主体可以为设备2;又比如,步骤S101的执行主体可以为设备1,步骤S102和步骤S103的执行主体可以为设备2;等等。
基于图1所示的区块链共识方法,本申请实施例还对应提供一种区块链共识装置的结构示意图,如图2所示。
图2为本申请实施例提供的一种区块链共识装置的结构示意图,包括:
确定模块201,接收业务数据,确定所述业务数据的受理时间;
存储模块202,存储携带所述受理时间的所述业务数据;
选择模块203,当需要对业务数据进行共识时,根据所述受理时间,选择待共识的业务数据;
共识模块204,对选择的所述待共识的业务数据进行共识。
在本申请的另一个实施例中,所述确定模块201确定所述业务数据的受理时间,具体包括:
确定接收到所述业务数据的时间,将所述时间确定为所述业务数据的受理时间;或者
在接收到所述业务数据时,对所述业务数据进行处理,得到处理结果,将所述处理结果的生成时间确定为所述业务数据的受理时间。
在本申请的另一个实施例中,所述装置还包括:广播模块205,其中:
所述广播模块205,在确定所述业务数据的受理时间后,将携带所述受理时间的所述业务数据广播至所述区块链中的其他节点。
在本申请的另一个实施例中,所述确定模块201接收业务数据,确定所述业务数据的受理时间,包括:
通过广播的方式接收所述区块链中其他节点发送的业务数据;
将所述业务数据中包含的受理时间确定为所述业务数据的受理时间。
在本申请的另一个实施例中,所述选择模块203根据所述受理时间,选择待共识的业务数据,具体包括:
按照所述受理时间的时间先后顺序,选择出满足待存储的区块的区块容量的待共识业务数据。
具体的,如图2所示的一种区块链共识装置可以位于服务器中,该服务器可以单独的一台设备,或者由多台设备组成的系统。或者,该共识装置也可位于终端中,如,手机,平板电脑,个人电脑等设备。
在20世纪90年代,对于一个技术的改进可以很明显地区分是硬件上的改进(例如,对二极管、晶体管、开关等电路结构的改进)还是软件上的改进(对于方法流程的改进)。然而,随着技术的发展,当今的很多方法流程的改进已经可以视为硬件电路结构的直接改进。设计人员几乎都通过将改进的方法流程编程到硬件电路中来得到相应的硬件电路结构。因此,不能说一个方法流程的改进就不能用硬件实体模块来实现。例如,可编程逻辑器件(Programmable Logic Device,PLD)(例如现场可编程门阵列(Field ProgrammableGateArray,FPGA))就是这样一种集成电路,其逻辑功能由用户对器件编程来确定。由设计人员自行编程来把一个数字系统“集成”在一片PLD上,而不需要请芯片制造厂商来设计和制作专用的集成电路芯片。而且,如今,取代手工地制作集成电路芯片,这种编程也多半改用“逻辑编译器(logic compiler)”软件来实现,它与程序开发撰写时所用的软件编译器相类似,而要编译之前的原始代码也得用特定的编程语言来撰写,此称之为硬件描述语言(Hardware Description Language,HDL),而HDL也并非仅有一种,而是有许多种,如ABEL(Advanced Boolean Expression Language)、AHDL(Altera Hardware DescriptionLanguage)、Confluence、CUPL(Cornell University Programming Language)、HDCal、JHDL(Java Hardware Description Language)、Lava、Lola、MyHDL、PALASM、RHDL(RubyHardware Description Language)等,目前最普遍使用的是VHDL(Very-High-SpeedIntegrated Circuit Hardware Description Language)与Verilog。本领域技术人员也应该清楚,只需要将方法流程用上述几种硬件描述语言稍作逻辑编程并编程到集成电路中,就可以很容易得到实现该逻辑方法流程的硬件电路。
控制器可以按任何适当的方式实现,例如,控制器可以采取例如微处理器或处理器以及存储可由该(微)处理器执行的计算机可读程序代码(例如软件或固件)的计算机可读介质、逻辑门、开关、专用集成电路(Application Specific Integrated Circuit,ASIC)、可编程逻辑控制器和嵌入微控制器的形式,控制器的例子包括但不限于以下微控制器:ARC 625D、Atmel AT91SAM、Microchip PIC18F26K20以及Silicone Labs C8051F320,存储器控制器还可以被实现为存储器的控制逻辑的一部分。本领域技术人员也知道,除了以纯计算机可读程序代码方式实现控制器以外,完全可以通过将方法步骤进行逻辑编程来使得控制器以逻辑门、开关、专用集成电路、可编程逻辑控制器和嵌入微控制器等的形式来实现相同功能。因此这种控制器可以被认为是一种硬件部件,而对其内包括的用于实现各种功能的装置也可以视为硬件部件内的结构。或者甚至,可以将用于实现各种功能的装置视为既可以是实现方法的软件模块又可以是硬件部件内的结构。
上述实施例阐明的系统、装置、模块或单元,具体可以由计算机芯片或实体实现,或者由具有某种功能的产品来实现。一种典型的实现设备为计算机。具体的,计算机例如可以为个人计算机、膝上型计算机、蜂窝电话、相机电话、智能电话、个人数字助理、媒体播放器、导航设备、电子邮件设备、游戏控制台、平板计算机、可穿戴设备或者这些设备中的任何设备的组合。
为了描述的方便,描述以上装置时以功能分为各种单元分别描述。当然,在实施本申请时可以把各单元的功能在同一个或多个软件和/或硬件中实现。
本领域内的技术人员应明白,本发明的实施例可提供为方法、系统、或计算机程序产品。因此,本发明可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本发明是参照根据本发明实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
在一个典型的配置中,计算设备包括一个或多个处理器(CPU)、输入/输出接口、网络接口和内存。
内存可能包括计算机可读介质中的非永久性存储器,随机存取存储器(RAM)和/或非易失性内存等形式,如只读存储器(ROM)或闪存(flash RAM)。内存是计算机可读介质的示例。
计算机可读介质包括永久性和非永久性、可移动和非可移动媒体可以由任何方法或技术来实现信息存储。信息可以是计算机可读指令、数据结构、程序的模块或其他数据。计算机的存储介质的例子包括,但不限于相变内存(PRAM)、静态随机存取存储器(SRAM)、动态随机存取存储器(DRAM)、其他类型的随机存取存储器(RAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、快闪记忆体或其他内存技术、只读光盘只读存储器(CD-ROM)、数字多功能光盘(DVD)或其他光学存储、磁盒式磁带,磁带磁磁盘存储或其他磁性存储设备或任何其他非传输介质,可用于存储可以被计算设备访问的信息。按照本文中的界定,计算机可读介质不包括暂存电脑可读媒体(transitory media),如调制的数据信号和载波。
还需要说明的是,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、商品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、商品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个......”限定的要素,并不排除在包括所述要素的过程、方法、商品或者设备中还存在另外的相同要素。
本领域技术人员应明白,本申请的实施例可提供为方法、系统或计算机程序产品。因此,本申请可采用完全硬件实施例、完全软件实施例或结合软件和硬件方面的实施例的形式。而且,本申请可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本申请可以在由计算机执行的计算机可执行指令的一般上下文中描述,例如程序模块。一般地,程序模块包括执行特定任务或实现特定抽象数据类型的例程、程序、对象、组件、数据结构等等。也可以在分布式计算环境中实践本申请,在这些分布式计算环境中,由通过通信网络而被连接的远程处理设备来执行任务。在分布式计算环境中,程序模块可以位于包括存储设备在内的本地和远程计算机存储介质中。
本说明书中的各个实施例均采用递进的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于系统实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
以上所述仅为本申请的实施例而已,并不用于限制本申请。对于本领域技术人员来说,本申请可以有各种更改和变化。凡在本申请的精神和原理之内所作的任何修改、等同替换、改进等,均应包含在本申请的权利要求范围之内。
Claims (29)
1.一种区块链共识方法,所述方法应用于区块链的共识节点,包括:
接收业务请求,确定所述业务请求对应的业务数据以及所述业务数据的受理时间,将所述受理时间加入所述业务数据中以使所述业务数据携带所述受理时间,并存储携带所述受理时间的所述业务数据;或,
接收并存储所述区块链中的其他共识节点发送的携带受理时间的业务数据;所述受理时间是由接收用户或者其他设备发送的业务请求的节点确定的,所述受理时间在所述区块链中是唯一的;
当需要对业务数据进行共识时,根据存储的各业务数据携带的受理时间的时间先后顺序,选择待共识的业务数据,并对选择的所述待共识的业务数据进行共识。
2.如权利要求1所述的方法,确定所述业务数据的受理时间,包括:
确定接收到所述业务请求的时间,将所述接收到所述业务请求的时间确定为所述业务数据的受理时间;
或,
确定受理所述业务请求的时间,将所述受理所述业务请求的时间确定为所述业务数据的受理时间;
或
接收到所述业务请求后,对所述业务数据进行处理并得到处理结果,将所述处理结果的生成时间确定为所述业务数据的受理时间。
3.如权利要求1所述的方法,若接收到业务请求,则确定所述业务请求对应的业务数据以及所述业务数据的受理时间,将所述受理时间加入所述业务数据中以使所述业务数据携带所述受理时间后,所述方法还包括:
将携带所述受理时间的所述业务数据广播至所述区块链中的其他节点。
4.如权利要求1所述的方法,接收并存储所述区块链中的其他共识节点发送的携带受理时间的业务数据包括:
通过广播的方式接收所述区块链中其他共识节点发送的业务数据;
将接收到的所述业务数据携带的受理时间确定为接收到的所述业务数据的受理时间。
5.如权利要求1所述的方法,将所述受理时间加入所述业务数据中包括:
若所述业务数据具有时间戳属性且所述时间戳属性为空,则将所述受理时间写入所述时间戳属性中;
或,
若所述业务数据具有时间戳属性且所述时间戳属性已经写入数据,则为所述业务数据添加受理时间属性,并将所述受理时间写入所述受理时间属性中;
或,
若所述业务数据没有时间戳属性,则为所述业务数据添加受理时间属性,并将所述受理时间写入所述受理时间属性中。
6.如权利要求1所述的方法,根据存储的各业务数据携带的受理时间,选择待共识的业务数据包括:
按照存储的各业务数据的受理时间的时间先后顺序,从所述存储的各业务数据中选择待共识的业务数据。
7.如权利要求1所述的方法,根据存储的各业务数据携带的受理时间,选择待共识的业务数据包括:
按照存储的各业务数据的受理时间的时间先后顺序,从所述存储的各业务数据中选择出满足待存储的区块的区块容量的业务数据作为待共识业务数据。
8.如权利要求7所述的方法,根据存储的各业务数据携带的受理时间,选择待共识的业务数据前,所述方法还包括:
根据区块链共识机制,确定待存储的区块的区块容量。
9.如权利要求8所述的方法,确定待存储的区块的区块容量后,所述方法还包括:
根据存储的各业务数据的摘要的占用空间大小以及所述待存储的区块的区块容量确定所述待存储的区块可记录的业务数据的数量。
10.如权利要求9所述的方法,选择的待共识业务数据的数量为所述待存储的区块可记录的业务数据的数量。
11.如权利要求1所述的方法,存储携带所述受理时间的所述业务数据包括:
将携带所述受理时间的所述业务数据以列表形式存储在所述共识节点的缓存中;
根据存储的各业务数据携带的受理时间,选择待共识的业务数据包括:
按照存储的各业务数据的受理时间的时间先后顺序,从所述存储的各业务数据的列表中按顺序选择出满足待存储的区块的区块容量的业务数据作为待共识业务数据。
12.如权利要求1所述的方法,若接收到其他区块链节点发送的携带受理时间的业务数据,所述方法还包括:
判断所述共识节点是否已存储所述接收到的业务数据,若否,则存储所述接收到的业务数据。
13.如权利要求1所述的方法,若接收到其他区块链节点发送的携带受理时间的业务数据,则接收到的所述业务数据携带的所述受理时间是由受理所述接收到的业务数据对应的业务请求的节点确定的。
14.如权利要求1所述的方法,存储携带所述受理时间的所述业务数据包括:
将携带所述受理时间的所述业务数据存储在所述共识节点的缓存中。
15.如权利要求1所述的方法,存储携带所述受理时间的所述业务数据包括:
根据受理时间将所述业务数据加入所述共识节点的业务数据列表中。
16.如权利要求1所述的方法,所述受理时间为所述共识节点本地的时间戳。
17.一种区块链共识装置,包括:
确定模块,用于接收业务请求,确定所述业务请求对应的业务数据以及所述业务数据的受理时间,将所述受理时间加入所述业务数据中以使所述业务数据携带所述受理时间;或,
接收所述区块链中的其他共识节点发送的携带受理时间的业务数据;所述受理时间是由接收用户或者其他设备发送的业务请求的节点确定的,所述受理时间在所述区块链中是唯一的;
存储模块,用于存储携带所述受理时间的所述业务数据;
选择模块,用于当需要对业务数据进行共识时,根据存储的各业务数据携带的受理时间的时间先后顺序,选择待共识的业务数据;
共识模块,用于对选择的所述待共识的业务数据进行共识。
18.如权利要求17所述的装置,确定所述业务数据的受理时间,包括:
确定接收到所述业务请求的时间,将所述接收到所述业务请求的时间确定为所述业务数据的受理时间;
或,
确定受理所述业务请求的时间,将所述受理所述业务请求的时间确定为所述业务数据的受理时间;
或
接收到所述业务请求后,对所述业务数据进行处理并得到处理结果,将所述处理结果的生成时间确定为所述业务数据的受理时间。
19.如权利要求17所述的装置,所述确定模块还用于:若接收到业务请求,则确定所述业务请求对应的业务数据以及所述业务数据的受理时间,将所述受理时间加入所述业务数据中以使所述业务数据携带所述受理时间后,将携带所述受理时间的所述业务数据广播至所述区块链中的其他节点。
20.如权利要求17所述的装置,接收所述区块链中的其他共识节点发送的携带受理时间的业务数据包括:
通过广播的方式接收所述区块链中其他共识节点发送的业务数据;
将接收到的所述业务数据携带的受理时间确定为接收到的所述业务数据的受理时间。
21.如权利要求17所述的装置,将所述受理时间加入所述业务数据中包括:
若所述业务数据具有时间戳属性且所述时间戳属性为空,则将所述受理时间写入所述时间戳属性中;
或,
若所述业务数据具有时间戳属性且所述时间戳属性已经写入数据,则为所述业务数据添加受理时间属性,并将所述受理时间写入所述受理时间属性中;
或,
若所述业务数据没有时间戳属性,则为所述业务数据添加受理时间属性,并将所述受理时间写入所述受理时间属性中。
22.如权利要求17所述的装置,根据存储的各业务数据携带的受理时间,选择待共识的业务数据包括:
按照存储的各业务数据的受理时间的时间先后顺序,从所述存储的各业务数据中选择待共识的业务数据。
23.如权利要求17所述的装置,根据存储的各业务数据携带的受理时间,选择待共识的业务数据包括:
按照存储的各业务数据的受理时间的时间先后顺序,从所述存储的各业务数据中选择出满足待存储的区块的区块容量的业务数据作为待共识业务数据。
24.如权利要求23所述的装置,所述选择模块还用于:根据存储的各业务数据携带的受理时间,选择待共识的业务数据前,根据区块链共识机制,确定待存储的区块的区块容量。
25.如权利要求24所述的装置,所述选择模块还用于:确定待存储的区块的区块容量后,根据存储的各业务数据的摘要的占用空间大小以及所述待存储的区块的区块容量确定所述待存储的区块可记录的业务数据的数量。
26.如权利要求25所述的装置,选择的待共识业务数据的数量为所述待存储的区块可记录的业务数据的数量。
27.如权利要求17所述的装置,存储携带所述受理时间的所述业务数据包括:
将携带所述受理时间的所述业务数据以列表形式存储在共识节点的缓存中;
根据存储的各业务数据携带的受理时间,选择待共识的业务数据包括:
按照存储的各业务数据的受理时间的时间先后顺序,从所述存储的各业务数据的列表中按顺序选择出满足待存储的区块的区块容量的业务数据作为待共识业务数据。
28.如权利要求17所述的装置,所述存储模块还用于:
若接收到其他区块链节点发送的携带受理时间的业务数据,判断共识节点是否已存储所述接收到的业务数据,若否,则存储所述接收到的业务数据。
29.如权利要求17所述的装置,若接收到其他区块链节点发送的携带受理时间的业务数据,则接收到的所述业务数据携带的所述受理时间是由受理所述接收到的业务数据对应的业务请求的节点确定的。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010594039.6A CN111756550B (zh) | 2017-03-28 | 2017-03-28 | 一种区块链共识方法及装置 |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710191996.2A CN107450979B (zh) | 2017-03-28 | 2017-03-28 | 一种区块链共识方法及装置 |
CN202010594039.6A CN111756550B (zh) | 2017-03-28 | 2017-03-28 | 一种区块链共识方法及装置 |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201710191996.2A Division CN107450979B (zh) | 2017-03-28 | 2017-03-28 | 一种区块链共识方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN111756550A CN111756550A (zh) | 2020-10-09 |
CN111756550B true CN111756550B (zh) | 2023-08-22 |
Family
ID=60486456
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201710191996.2A Active CN107450979B (zh) | 2017-03-28 | 2017-03-28 | 一种区块链共识方法及装置 |
CN202010594039.6A Active CN111756550B (zh) | 2017-03-28 | 2017-03-28 | 一种区块链共识方法及装置 |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201710191996.2A Active CN107450979B (zh) | 2017-03-28 | 2017-03-28 | 一种区块链共识方法及装置 |
Country Status (8)
Country | Link |
---|---|
US (3) | US10797886B2 (zh) |
EP (1) | EP3547129A4 (zh) |
JP (1) | JP6876806B2 (zh) |
KR (1) | KR102208186B1 (zh) |
CN (2) | CN107450979B (zh) |
PH (1) | PH12019501499A1 (zh) |
TW (1) | TWI752118B (zh) |
WO (1) | WO2018177235A1 (zh) |
Families Citing this family (31)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107450979B (zh) | 2017-03-28 | 2020-06-02 | 创新先进技术有限公司 | 一种区块链共识方法及装置 |
CN111866008B (zh) | 2017-07-14 | 2022-05-31 | 创新先进技术有限公司 | 一种业务数据处理方法、业务处理方法及设备 |
CN107992356B (zh) * | 2017-12-13 | 2021-09-14 | 深圳壹账通智能科技有限公司 | 区块链事务区块处理方法、电子装置及可读存储介质 |
CN108596619B (zh) * | 2018-04-26 | 2022-11-01 | 深圳怡化电脑股份有限公司 | 用于区块链系统的交易方法、装置、中心节点及系统 |
CN108665363B (zh) * | 2018-05-09 | 2021-08-03 | 合肥达朴汇联科技有限公司 | 一种区块链共识达成装置 |
CN109035016B (zh) * | 2018-06-28 | 2020-10-23 | 杭州复杂美科技有限公司 | 一种多链并发交易方法 |
CN108985011A (zh) * | 2018-07-23 | 2018-12-11 | 北京聚道科技有限公司 | 一种基于区块链技术的基因组数据管理方法及系统 |
CN108900364B (zh) * | 2018-08-22 | 2021-11-26 | 泰康保险集团股份有限公司 | 区块链网络的管理方法、装置、介质及电子设备 |
TWI698100B (zh) * | 2018-09-18 | 2020-07-01 | 柯賓漢數位金融科技有限公司 | 多區塊鏈產生及整合方法暨區塊鏈系統 |
CN111833189A (zh) * | 2018-10-26 | 2020-10-27 | 创新先进技术有限公司 | 数据处理方法及装置 |
CN110008686B (zh) * | 2018-11-16 | 2020-12-04 | 创新先进技术有限公司 | 跨区块链的数据处理方法、装置、客户端、区块链系统 |
CN111291110A (zh) * | 2018-12-06 | 2020-06-16 | 中国电信股份有限公司 | 基于区块链网络的共识方法和系统 |
CN109857751A (zh) * | 2019-01-23 | 2019-06-07 | 平安科技(深圳)有限公司 | 基于区块链的跨平台数据更新方法、装置和计算机设备 |
CN109951290B (zh) * | 2019-01-31 | 2022-03-01 | 创新先进技术有限公司 | 一种链式账本的授时认证方法、装置及设备 |
KR102354776B1 (ko) * | 2019-03-04 | 2022-01-25 | 어드밴스드 뉴 테크놀로지스 씨오., 엘티디. | 트랜잭션 데이터를 처리를 위해 블록체인 시스템에 제공하기 위한 방법 및 디바이스 |
CN110555079B (zh) * | 2019-09-04 | 2023-09-26 | 腾讯科技(深圳)有限公司 | 数据处理方法、装置、设备以及存储介质 |
CN110545190B (zh) * | 2019-09-06 | 2021-08-13 | 腾讯科技(深圳)有限公司 | 一种签名处理的方法、相关装置以及设备 |
CN110908801B (zh) * | 2019-11-12 | 2022-07-12 | 金蝶软件(中国)有限公司 | 基于区块链的数据处理方法、装置、计算机设备和存储介质 |
CN111131254B (zh) * | 2019-12-25 | 2022-04-15 | 中国联合网络通信集团有限公司 | 文件处理方法、区块链节点、区块链和存储介质 |
CN111259078B (zh) * | 2020-01-15 | 2023-10-10 | 广州运通链达金服科技有限公司 | 区块链共识方法、装置、计算机设备和存储介质 |
US11263216B2 (en) * | 2020-01-31 | 2022-03-01 | International Business Machines Corporation | Decentralized aggregation and collection of data from multiple sources |
CN111461885B (zh) * | 2020-03-31 | 2024-03-19 | 财付通支付科技有限公司 | 共识网络管理方法、装置、计算机以及可读存储介质 |
CN111506783B (zh) * | 2020-04-08 | 2023-12-22 | 百度在线网络技术(北京)有限公司 | 区块链中事务请求处理方法、装置、设备和介质 |
CN111507719B (zh) * | 2020-04-22 | 2023-04-28 | 北京众享比特科技有限公司 | 一种中心化方式动态更新联盟链验证节点的方法和系统 |
CN111654415B (zh) * | 2020-05-28 | 2021-09-10 | 腾讯科技(深圳)有限公司 | 基于区块链的信息处理方法、装置、设备及可读存储介质 |
CN113256426B (zh) * | 2020-05-29 | 2023-08-04 | 支付宝(杭州)信息技术有限公司 | 一种数据处理方法、装置、设备及介质 |
CN111698315B (zh) * | 2020-06-09 | 2021-10-15 | 腾讯科技(深圳)有限公司 | 针对区块的数据处理方法、数据处理装置及计算机设备 |
US11909171B2 (en) | 2021-03-31 | 2024-02-20 | Apple Inc. | Laser-integrated balance detection for self-mixing interferometry |
KR20220137329A (ko) * | 2021-04-02 | 2022-10-12 | 삼성전자주식회사 | 블록 체인에 기반하여 블록 합의를 수행하는 전자 장치 및 그 운용 방법 |
CN113781230A (zh) * | 2021-09-24 | 2021-12-10 | 支付宝(杭州)信息技术有限公司 | 基于区块链的交易处理方法和装置 |
CN115086434B (zh) * | 2022-06-14 | 2024-04-16 | 中国银行股份有限公司 | 基于区块链的银行业务办理方法及装置 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN105573732A (zh) * | 2014-10-14 | 2016-05-11 | 阿里巴巴集团控股有限公司 | 一种基于分布式系统的业务对象的处理方法和装置 |
CN105912618A (zh) * | 2016-04-07 | 2016-08-31 | 浙江万马新能源有限公司 | 基于区块链的充电桩充电交易通讯方法及装置 |
CN106411774A (zh) * | 2016-09-06 | 2017-02-15 | 联动优势科技有限公司 | 一种控制交易数据量的方法和装置 |
CN106446067A (zh) * | 2016-09-06 | 2017-02-22 | 联动优势科技有限公司 | 一种获取交易数据的方法和装置 |
Family Cites Families (29)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2002074207A (ja) | 2000-09-04 | 2002-03-15 | Fujitsu Ltd | サーバー |
US7797434B2 (en) * | 2002-12-31 | 2010-09-14 | International Business Machines Corporation | Method and system for user-determind attribute storage in a federated environment |
US7849223B2 (en) * | 2007-12-07 | 2010-12-07 | Microsoft Corporation | Virtually synchronous Paxos |
KR100981856B1 (ko) * | 2010-02-26 | 2010-09-13 | 현대하이스코 주식회사 | 도금성이 우수한 고강도 강판 제조 방법 |
CN102999529B (zh) * | 2011-09-16 | 2015-09-16 | 腾讯科技(深圳)有限公司 | 平台间信息共享系统及方法 |
US10409827B2 (en) | 2014-10-31 | 2019-09-10 | 21, Inc. | Digital currency mining circuitry having shared processing logic |
US10015279B2 (en) * | 2014-11-13 | 2018-07-03 | Blackberry Limited | Application assignment reconciliation and license management |
US9436923B1 (en) * | 2015-02-26 | 2016-09-06 | Skuchain, Inc. | Tracking unitization occurring in a supply chain |
JP5858506B1 (ja) * | 2015-04-09 | 2016-02-10 | 株式会社Orb | 仮想通貨管理プログラム、及び仮想通貨管理方法 |
US9942046B2 (en) * | 2015-05-06 | 2018-04-10 | 21, Inc. | Digital currency mining circuitry with adaptable difficulty compare capabilities |
JP5858507B1 (ja) * | 2015-05-18 | 2016-02-10 | 株式会社Orb | 仮想通貨管理プログラム、及び仮想通貨管理方法 |
US20160342977A1 (en) * | 2015-05-20 | 2016-11-24 | Vennd.io Pty Ltd | Device, method and system for virtual asset transactions |
WO2017010455A1 (ja) | 2015-07-13 | 2017-01-19 | 日本電信電話株式会社 | 契約合意方法、合意検証方法、契約合意システム、合意検証装置、契約合意装置、契約合意プログラム及び合意検証プログラム |
US9529923B1 (en) * | 2015-08-28 | 2016-12-27 | Swirlds, Inc. | Methods and apparatus for a distributed database within a network |
CN105488675B (zh) | 2015-11-25 | 2019-12-24 | 布比(北京)网络技术有限公司 | 一种区块链的分布式共享总账构建方法 |
CN105790954B (zh) * | 2016-03-02 | 2019-04-09 | 布比(北京)网络技术有限公司 | 一种构建电子证据的方法和系统 |
CN106534273B (zh) * | 2016-10-31 | 2022-04-15 | 中金云金融(北京)大数据科技股份有限公司 | 区块链元数据存储系统及其存储方法与检索方法 |
PT3539026T (pt) * | 2016-11-10 | 2022-03-08 | Swirlds Inc | Métodos e aparelhos para uma base de dados distribuída que inclui entradas anónimas |
CN106534317B (zh) * | 2016-11-17 | 2019-09-03 | 杭州云象网络技术有限公司 | 一种基于区块链技术的灾备云存储系统构建方法 |
US10862959B2 (en) * | 2016-11-28 | 2020-12-08 | Keir Finlow-Bates | Consensus system and method for adding data to a blockchain |
US10356102B2 (en) * | 2017-02-24 | 2019-07-16 | Verizon Patent And Licensing Inc. | Permissions using blockchain |
US10375105B2 (en) | 2017-03-03 | 2019-08-06 | International Business Machines Corporation | Blockchain web browser interface |
CN107450979B (zh) | 2017-03-28 | 2020-06-02 | 创新先进技术有限公司 | 一种区块链共识方法及装置 |
CN107391527B (zh) * | 2017-03-28 | 2020-03-27 | 创新先进技术有限公司 | 一种基于区块链的数据处理方法及设备 |
CN107239479B (zh) * | 2017-03-28 | 2020-03-13 | 创新先进技术有限公司 | 一种基于区块链的数据存储以及查询的方法及装置 |
CN113282659A (zh) * | 2017-03-28 | 2021-08-20 | 创新先进技术有限公司 | 一种基于区块链的数据处理方法及设备 |
CN107360206B (zh) * | 2017-03-29 | 2020-03-27 | 创新先进技术有限公司 | 一种区块链共识方法、设备及系统 |
US10102526B1 (en) * | 2017-03-31 | 2018-10-16 | Vijay K. Madisetti | Method and system for blockchain-based combined identity, ownership, integrity and custody management |
CN107450981B (zh) * | 2017-05-31 | 2020-04-24 | 创新先进技术有限公司 | 一种区块链共识方法及设备 |
-
2017
- 2017-03-28 CN CN201710191996.2A patent/CN107450979B/zh active Active
- 2017-03-28 CN CN202010594039.6A patent/CN111756550B/zh active Active
- 2017-11-21 TW TW106140233A patent/TWI752118B/zh active
-
2018
- 2018-03-26 KR KR1020197018685A patent/KR102208186B1/ko active IP Right Grant
- 2018-03-26 WO PCT/CN2018/080439 patent/WO2018177235A1/zh unknown
- 2018-03-26 JP JP2019535948A patent/JP6876806B2/ja active Active
- 2018-03-26 EP EP18774835.5A patent/EP3547129A4/en not_active Withdrawn
-
2019
- 2019-06-26 PH PH12019501499A patent/PH12019501499A1/en unknown
- 2019-09-27 US US16/585,407 patent/US10797886B2/en active Active
-
2020
- 2020-01-07 US US16/736,644 patent/US10785039B2/en active Active
- 2020-07-31 US US16/945,267 patent/US10887112B2/en active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN105573732A (zh) * | 2014-10-14 | 2016-05-11 | 阿里巴巴集团控股有限公司 | 一种基于分布式系统的业务对象的处理方法和装置 |
CN105912618A (zh) * | 2016-04-07 | 2016-08-31 | 浙江万马新能源有限公司 | 基于区块链的充电桩充电交易通讯方法及装置 |
CN106411774A (zh) * | 2016-09-06 | 2017-02-15 | 联动优势科技有限公司 | 一种控制交易数据量的方法和装置 |
CN106446067A (zh) * | 2016-09-06 | 2017-02-22 | 联动优势科技有限公司 | 一种获取交易数据的方法和装置 |
Non-Patent Citations (1)
Title |
---|
区块链技术综述;沈鑫 等;《网络与信息安全学报》;20161130;第2卷(第11期);第00107-1-00107-10页 * |
Also Published As
Publication number | Publication date |
---|---|
KR20190091484A (ko) | 2019-08-06 |
US10797886B2 (en) | 2020-10-06 |
CN107450979A (zh) | 2017-12-08 |
US20200366501A1 (en) | 2020-11-19 |
JP6876806B2 (ja) | 2021-05-26 |
PH12019501499A1 (en) | 2020-06-08 |
JP2020509445A (ja) | 2020-03-26 |
US10785039B2 (en) | 2020-09-22 |
TWI752118B (zh) | 2022-01-11 |
EP3547129A4 (en) | 2019-12-11 |
US20200028692A1 (en) | 2020-01-23 |
US20200145228A1 (en) | 2020-05-07 |
CN111756550A (zh) | 2020-10-09 |
KR102208186B1 (ko) | 2021-01-29 |
EP3547129A1 (en) | 2019-10-02 |
WO2018177235A1 (zh) | 2018-10-04 |
TW201837735A (zh) | 2018-10-16 |
US10887112B2 (en) | 2021-01-05 |
CN107450979B (zh) | 2020-06-02 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN111756550B (zh) | 一种区块链共识方法及装置 | |
CN107450981B (zh) | 一种区块链共识方法及设备 | |
JP6716149B2 (ja) | ブロックチェーンベースのデータ処理方法および装置 | |
CN107391526B (zh) | 一种基于区块链的数据处理方法及设备 | |
CN106899666B (zh) | 一种针对业务标识的数据处理方法及装置 | |
CN108628688B (zh) | 一种消息处理方法、装置及设备 | |
CN109002357B (zh) | 资源分配方法、装置及物联网系统 | |
CN110046187B (zh) | 数据处理系统、方法及装置 | |
CN107578338B (zh) | 一种业务发布方法、装置及设备 | |
CN111402058B (zh) | 一种数据处理方法、装置、设备及介质 | |
CN111768303A (zh) | 交易处理方法、装置、设备及系统 | |
CN110276637B (zh) | 资源分配方法和装置、优惠券分配方法和装置 | |
CN115396375B (zh) | 一种业务处理方法、装置以及设备 | |
CN116089046A (zh) | 基于软件定义算力网络的调度方法、装置、设备及介质 | |
CN115033350A (zh) | 一种分布式事务的执行方法及装置 | |
CN110245115B (zh) | 一种文件处理方法、引擎及系统 | |
CN109614388B (zh) | 一种预算扣减方法和装置 | |
CN117041980B (zh) | 一种网元管理方法、装置、存储介质及电子设备 | |
CN117348999B (zh) | 一种业务执行系统及业务执行方法 | |
CN112686533A (zh) | 一种资源分配方法、设备、介质及电子设备 | |
CN115774705A (zh) | 一种事务提交方法及装置 | |
CN113435992A (zh) | 一种记账方法、装置以及设备 | |
CN114912990A (zh) | 一种数据处理的方法及装置 | |
CN116128496A (zh) | 交易记账处理方法及装置 | |
CN117808587A (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 | ||
REG | Reference to a national code |
Ref country code: HK Ref legal event code: DE Ref document number: 40039065 Country of ref document: HK |
|
GR01 | Patent grant | ||
GR01 | Patent grant |