一种区块生成方法及共识节点
技术领域
本文件涉及区块链技术领域,尤其涉及一种区块生成方法及共识节点。
背景技术
在区块链系统中,每个区块的时间戳就像区块号一样必须是顺序递增的。目前绝大部分区块链系统采用的是拜占庭容错(BFT,Byzantine Fault-Tolerant)共识协议。在BFT共识协议中,区块的时间戳是由提议发起者决定的,如果提议发起者作恶,会导致整条链区块的时间有序性遭到破坏。此外,对于一些需要追溯时间的区块链业务,也要在区块的时间戳正确的情况下,才能执行的业务决策。
为此,当前亟需一种保证新增区块的时间戳相对上一区块的时间戳呈递增的技术方案。
发明内容
本说明书实施例目的是提供一种区块生成方法及共识节点,能够保证新增区块的时间戳相对上一区块的时间戳呈递增。
为了实现上述目的,本说明书实施例是这样实现的:
第一方面,提供一种区块生成方法,包括:
区块链的第一共识节点发起携带有所述第一共识节点提供的第一时间戳的目标共识提议;
所述区块链的第二共识节点在接收到所述目标共识提议后,基于所述目标共识提议的接收时间,确定第二时间戳;
所述第二共识节点基于本地结尾区块的第三时间戳和所述第二时间戳,对所述第一时间戳进行校验,以在校验通过后对所述目标共识提议的提议数据执行共识逻辑;
若所述目标共识提议达成共识,则所述第一共识节点和所述第二共识节点生成记录有所述目标共识提议的提议数据的新增区块,其中,生成的所述新增区块的第四时间戳是至少基于所述第一时间戳确定得到的,且不早于所属共识节点本地的其他区块的时间戳。
第二方面,提供一种区块链的共识节点,包括:
时间戳获取模块,在接收到区块链的其他共识节点发起的目标共识提议时,基于所述目标共识提议的接收时间,确定第二时间戳,其中,所述目标共识提议携带有所述其他共识节点提供的第一时间戳;
共识执行模块,基于本地结尾区块的第三时间戳和所述第二时间戳,对所述第一时间戳进行校验,以在校验通过后对所述目标共识提议的提议数据执行共识逻辑;
区块生成模块,若所述目标共识提议达成共识,则生成记录有所述目标共识提议的提议数据的新增区块,其中,生成的所述新增区块的第四时间戳是至少基于所述第一时间戳确定得到的,且不早于本地其他区块的时间戳;
共识发起模块,若基于所述区块链的共识协议需要发起共识提议时,发起携带有本地提供的时间戳的共识提议。
本说明书实施例的方案中,目标共识节点在发起目标共识提议时,携带自身提供的第一时间戳,其他共识节点在接收到目标共识提议时,基于本地当前时刻的第二时间戳和本地结尾区块的第三时间戳对目标共识节点提供的第一时间戳进行校验,并在校验通过后,再对目标共识提议的提议数据执行共识逻辑。若达成共识,则各共识节点生成由第一时间戳所确定的第四时间戳的新生区块,以记录目标共识提议中的提议数据。整个方案可以有效保证新生区块的时间戳相对上一区块的时间戳呈顺序递增,从而使得区块链中的区块在时间维度上具有有序性,确保一些需要追溯时间的区块链业务能够正确执行业务决策。
附图说明
为了更清楚地说明本说明书实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本说明书实施例中记载的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1为本说明书实施例提供的区块生成方法的第一种流程示意图。
图2为本说明书实施例提供的区块生成方法的第二种流程示意图。
图3为本说明书实施例提供的共识节点的结构示意图。
图4为本说明书实施例提供的区块链系统的结构示意图。
图5为本说明书实施例提供的电子设备的结构示意图。
具体实施方式
为了使本技术领域的人员更好地理解本说明书中的技术方案,下面将结合本说明书实施例中的附图,对本说明书实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本说明书一部分实施例,而不是全部的实施例。基于本说明书中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都应当属于本说明书保护的范围。
如前所述,在区块链系统中,每个区块的时间戳就像区块号一样必须是顺序递增的。目前的BFT共识协议下,区块的时间戳是由提议发起者决定的,如果提议发起者作恶,会导致整条链区块的时间有序性遭到破坏。此外,对于一些需要追溯时间的区块链业务,也要在区块的时间戳正确的情况下,才能执行的业务决策。在此背景下,本文旨在提供一种适用于BFT共识协议的保证新增区块的时间戳相对上一区块的时间戳呈递增的技术方案。
图1是本说明书实施例区块生成方法的流程图。图1所示的方法可以由下文相对应的装置执行,包括如下步骤:
S102,区块链的第一共识节点发起携带有第一共识节点提供的第一时间戳的目标共识提议。
与传统的BFT共识协议一样,第一共识节点可以将自身提出的第一时间戳携带在目标共识提议中。若目标共识提议达成共识,则第一时间戳用于确定新增区块的时间戳。在本说明书实施例中,为了避免第一共识节点的作恶行为,其他节点后续需要对第一时间戳进行校验。
S104,区块链的第二共识节点在接收到目标共识提议后,基于目标共识提议的接收时间,确定第二时间戳。
具体地,本步骤中,第二共识节点可以在接收到目标共识提议后,可以确定本地系统当前的时间戳,并将该当前的时间戳确定为第二时间戳。
S106,第二共识节点基于本地结尾区块的第三时间戳和第二时间戳,对第一时间戳进行校验,以在校验通过后对目标共识提议的提议数据执行共识逻辑。
应理解,如果第一共识节点按照区块的时间戳顺序递增的要求提供第一时间戳,则第一时间戳应晚于各共识节点的结尾区块的时间戳,并早于其他共识节点接收目标共识提议的时间。因此,第二共识节点可以基于这一特点对第一时间戳进行校验。若第一时间戳早于第二时间戳,且晚于第三时间戳,则校验通过;否则校验失败,可以直接拒绝第一共识节点提出的目标共识提议。
S108,若目标共识提议达成共识,则第一共识节点和第二共识节点生成记录有目标共识提议的提议数据的新增区块,其中,生成的新增区块的第四时间戳是至少基于第一时间戳确定得到的,且不早于所属共识节点本地的其他区块的时间戳。
具体地,目前常用的BFT共识协议主要包括:PBFT共识协议和HoneyBadgerBFT共识协议。
在HoneyBadgerBFT共识协议下,每轮共识中,所有共识节点均能够发起共识提议,因此生成的新增区块记录有共识阶段所有达成共识的共识提议的提议数据,对应的第四时间戳可以是基于包含第一时间戳在内的共识阶段所有达成共识的共识提议的时间戳所确定得到的。比如,第四时间戳为共识阶段所有达成共识的共识提议的时间戳的中值。
在PBFT共识协议下,共识节点需要划分出主共识节点和备份共识节点。在每轮共识中,只有主共识节点才能发起共识提议,因此生成的新增区块的第四时间戳可以直接采用第一时间戳。
基于图1所示的区块生成方法,本说明书实施例的方案中,目标共识节点在发起目标共识提议时,携带自身提供的第一时间戳,其他共识节点在接收到目标共识提议时,基于本地当前时刻的第二时间戳和本地结尾区块的第三时间戳对目标共识节点提供的第一时间戳进行校验,并在校验通过后,再对目标共识提议的提议数据执行共识逻辑。若达成共识,则各共识节点生成由第一时间戳所确定的第四时间戳的新生区块,以记录目标共识提议中的提议数据。整个方案可以有效保证新生区块的时间戳相对上一区块的时间戳呈顺序递增,从而使得区块链中的区块在时间维度上具有有序性,确保一些需要追溯时间的区块链业务能够正确执行业务决策。
下面对本说明书实施例的区块生成方法进行详细介绍。
应用场景一
本应用场景一中,区块链采用HoneyBadgerBFT共识协议。如前所述,HoneyBadgerBFT共识协议要求每个共识节点在共识节点均发起自己的共识提议,因此新增区块记录有本轮共识阶段所有达成共识的提议数据,而新增区块的时间戳所有达成共识的共识提议所携带的时间戳确定得到。
其中,HoneyBadgerBFT共识协议包括:可靠广播传输(RBC,Reliable Broadcast)协议阶段和二进协定(BA,Binary Agreement )协议阶段。本应用场景一中,共识节点在RBC协议阶段完成后,且进入二进制协定BA协议阶段之前,对共识提议中的时间戳进行校验。具体地的区块生成流程包括如下步骤:
S201,区块链的第一共识节点在RBC协议阶段,发起携带有第一时间戳的目标共识提议。
具体地,本步骤中,第一共识节点获取本地系统当前时间相关的第五时间戳和本地结尾区块的第六时间戳。其中,这里所述的当前时间相关的第五时间戳可以指当前时间的时间戳,也可以是与当前时间相近的时间戳,或者也可以是基于当前时间所确定的时间戳。
若第五时间戳晚于第六时间戳,则第一共识节点将第五时间戳作为第一时间戳,并发起发起携带有第一时间戳的目标共识提议;
若第五时间戳早于第六时间戳,则第一共识节点基于预设规则确定第一时间戳,并发起携带有第一时间戳的目标共识提议,其中,预设规则确定的第一时间戳是第六时间戳加上单位时间T获得的。
应理解, RBC协议阶段下,各共识节点均需要将自己的共识提供广播给其他共识节点,并接受其他节点发起的共识提议。这里,本文不再对(除目标共识提议以外的)其他共识提议作重复赘述。
S202,各共识节点执行RBC协议阶段的校验流程。
在RBC协议阶段的校验流程中,各共识节点基于其他共识节点的共识提议信息(即Echo信息)重构默克尔树,并校验重构的默克尔树。当校验通过后,共识节点向其他节点广播Ready消息。针对任一共识节点,当接收到来自收到 f+1个相同的且来自于不同节点的Ready 消息时(f是联盟链中作恶节点的数量),判断自身是否广播过 Ready 消息,没有则广播Ready消息;当收到 2f+1 个相同的且来自于不同节点的 Ready 消息时,则确认接收到正确的其他共识节点所发起的共识提议。
S203,第二共识节点在内的其他共识节点在RBC协议阶段的流程完成后,基于目标共识提议的接收时间,确定第二时间戳,并获取基于本地结尾区块的第三时间戳。
S204,第二共识节点在内的其他共识节点基于第二时间戳和第三时间戳和,对第一时间戳进行校验。其中,若第一时间戳早于第二时间戳,且晚于第三时间戳,则校验通过,执行S206;否则,校验失败执行S205。
S205,包含第二共识节点在内的其他共识节点将目标共识提议在协议阶段的BA取值设置为0。
其中,目标共识提议在BA取值0的情况下,无法通过本轮共识。
S206,各共识节点执行 BA协议阶段的流程。
其中,BA协议是各共识节点对单个共识提议在集群中达成一致的协议。只有,BA值为1的共识提议会在最终共识结果里,其包含提议数据会成功上链。
S207,各共识节点将BA值为1的所有共识提议中的时间戳组合一个集合,并将集合中的所有时间戳的中值确定第四时间戳。
此外,如果特殊原因导致集合为空集,比如,共识节点在共识提议中为提供能够被解析的时间戳,则共识节点还可以将本地结尾区块的第三时间戳+单位时间T作为新增区块的第四时间戳。
S208,各共识节点生成第四时间戳的新增区块,新增区块记录有本轮共识阶段所有达成共识提议的提议数据。
应用场景二
本应用场景二中,区块链采用PBFT共识协议。如前所述,PBFT共识协议要求只有主共识节点能够发起共识提议,因此新增区块只记录有主共识节点发起的共识提议的提议数据,若主共识节点在共识提议中提供的时间戳校验通过,则可以直接将主共识节点提供的时间戳作为新增区块的时间戳。
其中,不同于上述HoneyBadgerBFT共识协议,PBFT共识协议主要包括: pre-prepare阶段、prepare阶段和commit阶段。本应用场景二中备份共识节点(即上文所述的第二共识节点)在预准备pre-prepare阶段,对主共识节点(即上文所述的第一共识节点)发起的目标共识提议中的第一时间戳进行校验。
具体地的区块生成流程包括:
区块链的第一共识节点发起携带有第一时间戳的目标共识提议。
其中,共识过程包括:
pre-prepare阶段:
主共识节点收到来自Client的一个请求,并分配一个编号给这个请求,然后主共识节点会广播一条pre-prepare消息给备份共识节点,这个pre-prepare消息包含该请求的编号、所在的视图(view)和主共识节点的摘要(digest),同时还有调用指定智能合约的请求,这个请求指示智能合约的地址。
每一个备份共识节点在接收到pre-prepare消息后,确定同不同意主共识节点分配给该请求的这个编号n,即,确认是否接受这条pre-prepare消息。
各备份共识节点如果接受了这条pre-prepare消息,调用指定智能合约,按照指定智能合约的逻辑,基于目标共识提议的接收时间,确定第二时间戳,并获取基于本地结尾区块的第三时间戳,之后基于第二时间戳和第三时间戳和,对第一时间戳进行校验。
若校验通过,则进入prepare阶段。若未通过校验,则甚至直接打回对目标共识提议,共识流程结束。
prepare阶段:
所有参与共识的备份共识节点中的每一个在接收到 pre-prepare 消息后,检查pre-prepare消息是否合法。如果pre-prepare消息合法,那么该共识提议在replica上的状态被确定为prepared,备份共识节点将该pre-prepare消息添加到本地Log中,并发送prepare 消息给其他参与共识的备份共识节点。
commit阶段:
所有共识节点中的每一个在进入prepared 状态后,发送 commit 消息给其他共识节点,并将自己发送的commit消息添加到本地Log中(代表自己的认可)。当一个共识节点发现有一个quorum(quorum是为了能够确保所有 replica 数据一致性要求和容错要求需要的一定数量replica的集合)同意编号分配时,它就会广播一条commit消息给其它所有节点。与此同时也会陆续收到来自其他节点的commit消息,如果每个节点收到了2f+1(f是联盟链中作恶节点的数量)条commit消息(包括自身的一条,这些来自不同节点的commit携带相同的编号n和view v),就说名该共识节点拥有了一个名为committed certificate的证书,请求在这个共识节点上达到了committed状态。此时只通过这一个共识节点,就能断定该请求已经在一个quorum中到达了prepared状态,即同一个quorum的所有共识节点都同意了编号n的分配。当Client发起的请求到达commited状态后,说明已经达成全网共识。
应用场景三
本应用场景三中,区块链采用PBFT共识协议。其中,备份共识节点(即上文所述的第二共识节点)在prepare阶段,对主共识节点(即上文所述的第一共识节点)发起的目标共识提议中的第一时间戳进行校验。具体地的区块生成流程包括:
区块链的第一共识节点发起携带有第一时间戳的目标共识提议。
其中,共识过程包括:
pre-prepare阶段:
主共识节点收到来自Client的一个请求,并分配一个编号给这个请求,然后主共识节点会广播一条pre-prepare消息给备份共识节点,这个pre-prepare消息包含该请求的编号、所在的视图(view)和主共识节点的摘要(digest)。
每一个备份共识节点在接收到pre-prepare消息后,确定同不同意主共识节点分配给该交易请求的这个编号n,即,确认是否接受这条pre-prepare消息。各备份共识节点如果接受了这条pre-prepare消息,则进入prepare阶段。
prepare阶段:
所有参与共识的备份共识节点中的每一个在接收到 pre-prepare 消息后,调用预先在联盟链部署的指定智能合约,按照指定智能合约的逻辑,基于目标共识提议的接收时间,确定第二时间戳,并获取基于本地结尾区块的第三时间戳,之后基于第二时间戳和第三时间戳和,对第一时间戳进行校验。
若第一时间戳未通过验,则直接打回对本次目标共识提议,共识流程结束。
若校验通过,再检查pre-prepare消息是否合法。如果pre-prepare消息合法,那么该共识提议在replica上的状态被确定为prepared,备份共识节点将该pre-prepare消息添加到本地Log中,并发送 prepare 消息给其他备份共识节点。
commit阶段:
所有共识节点中的每一个在进入prepared 状态后,发送 commit 消息给其他共识节点,并将自己发送的commit消息添加到本地Log中。当一个共识节点发现有一个quorum同意编号分配时,它就会广播一条commit消息给其它所有节点。与此同时也会陆续收到来自其他节点的commit消息,如果每个节点收到了2f+1条commit消息,就说名该共识节点拥有了一个名为committed certificate的证书,请求在这个共识节点上达到了committed状态。此时只通过这一个共识节点,就能断定该请求已经在一个quorum中到达了prepared状态,即同一个quorum的所有共识节点都同意了编号n的分配。当Client发起的请求到达commited状态后,说明已经达成全网共识。
通过上述应用场景二和应用场景三可以知道,在传统的PBFT算法的共识过程中,备份共识节点在pre-prepare阶段开始执行共识逻辑,即备份共识节点在pre-prepare阶段检查主共识节点发送的第一时间戳是否合法。因此,备份共识节点业务校验的步骤可以在检查pre-prepare消息之前执行,一旦第一时间戳未能通过备份共识节点的校验,则拒绝执行后续的共识逻辑,从而避免造成不必要的资源开销。
以上是对本说明书实施例的方法的介绍。应理解,在不脱离本文上述原理基础之上,还可以进行适当的变化,这些变化也应视为本说明书实施例的保护范围。
与上述区块生成方法相对应的,本说明书实施例还提供一种区块链的共识节点。图3为共识节点300的结构示意图,包括:
时间戳获取模块310,在接收到区块链的其他共识节点发起的目标共识提议时,基于所述目标共识提议的接收时间,确定第二时间戳,其中,所述目标共识提议携带有所述其他共识节点提供的第一时间戳;
共识执行模块320,基于本地结尾区块的第三时间戳和所述第二时间戳,对所述第一时间戳进行校验,以在校验通过后对所述目标共识提议的提议数据执行共识逻辑;
区块生成模块330,若所述目标共识提议达成共识,则生成记录有所述目标共识提议的提议数据的新增区块,其中,生成的所述新增区块的第四时间戳是至少基于所述第一时间戳确定得到的,且不早于本地其他区块的时间戳;
共识发起模块340,若基于所述区块链的共识协议需要发起共识提议时,发起携带有本地提供的时间戳的共识提议。
本说明书实施例的共识节点在接收到其他节点发起目标共识提议时,基于本地当前时刻的第二时间戳和本地结尾区块的第三时间戳对目标共识节点中携带的其他节点提供的第一时间戳进行校验,并在校验通过后,再对目标共识提议的提议数据执行共识逻辑。若达成共识,则本地生成由第一时间戳所确定的第四时间戳的新生区块,以记录目标共识提议中的提议数据。整个方案可以有效保证新生区块的时间戳相对上一区块的时间戳呈顺序递增,从而使得区块链中的区块在时间维度上具有有序性,确保一些需要追溯时间的区块链业务能够正确执行业务决策。
可选地,共识执行模块320在执行时,具体若所述第一时间戳早于所述第二时间戳,且晚于所述第三时间戳,则校验通过,否则校验失败。
可选地,共识发起模块340在执行时,具体获取获取当前时间相关的第五时间戳和本地结尾区块的第六时间戳。若所述第五时间戳晚于所述第六时间戳,则发起发起携带有第五时间戳的共识提议;若若述第五时间戳早于所述第六时间戳,发起携带有第七时间戳的共识提议,其中,第七时间戳是第六时间戳加上单位时间获得的。
可选地,所述区块链采用基于蜜獾拜占庭容错算法的共识协议,所述目标共识提议所属的共识阶段还包括来自不同的其他共识节点所发起的共识提议,其中,生成的所述新增区块记录有所述共识阶段所有达成共识的共识提议的提议数据,且所述第四时间戳是基于包含所述第一时间戳在内的所述共识阶段所有达成共识的共识提议的时间戳所确定得到的。例如,所述第四时间戳为所述共识阶段所有达成共识的共识提议的时间戳的中值。
可选地,共识执行模块320在蜜獾拜占庭容错算法的可靠广播传输RBC协议阶段完成后,且进入二进制协定BA协议阶段之前,基于本地结尾区块的第三时间戳和所述第二时间戳,对所述第一时间戳进行校验。此外,若所述第一时间戳未通过校验,则共识执行模块320将所述目标共识提议在BA协议阶段的BA取值设置为0。
可选地,所述区块链采用实用拜占庭容错算法的共识协议,所述第一共识节点为所述区块链的主共识节点,所述第四时间戳等于所述第一时间戳。其中,共识执行模块320可以在实用拜占庭容错算法的预准备阶段或准备阶段,基于本地结尾区块的第三时间戳和所述第二时间戳,对所述第一时间戳进行校验。
应理解,本说明书实施例的共识节点可以作为图1所示的区块生成方法中的执行主体,因此能够实现区块生成方法在图1和图2所实现步骤和功能。由于原理相同,本文不再赘述。
与上述区块生成方法相对应的,本说明书实施例还提供一种区块链系统。图4为该区块链系统400的结构示意图,包括:包括多个共识节点410,其中所述多个共识节点410中的至少一者在接收到区块链的其他共识节点410发起的目标共识提议时执行:
基于所述目标共识提议的接收时间,确定第二时间戳,其中,所述目标共识提议携带有所述其他共识节点提供的第一时间戳;基于本地结尾区块的第三时间戳和所述第二时间戳,对所述第一时间戳进行校验,以在校验通过后对所述目标共识提议的提议数据执行共识逻辑;
若所述目标共识提议达成共识,则生成记录有所述目标共识提议的提议数据的新增区块,其中,生成的所述新增区块的第四时间戳是至少基于所述第一时间戳确定得到的,且不早于本地其他区块的时间戳;
若基于所述区块链的共识协议需要发起共识提议时,发起携带有本地提供的时间戳的共识提议。
显然,本说明书实施例的区块链系统可以实现上述图1所示的区块生成方法中的步骤和功能。由于原理相同,本文不再赘述。
图5是本说明书的一个实施例电子设备的结构示意图。请参考图5,在硬件层面,该电子设备包括处理器,可选地还包括内部总线、网络接口、存储器。其中,存储器可能包含内存,例如高速随机存取存储器(Random-Access Memory,RAM),也可能还包括非易失性存储器(non-volatile memory),例如至少1个磁盘存储器等。当然,该电子设备还可能包括其他业务所需要的硬件。
处理器、网络接口和存储器可以通过内部总线相互连接,该内部总线可以是ISA(Industry Standard Architecture,工业标准体系结构)总线、PCI(PeripheralComponent Interconnect,外设部件互连标准)总线或EISA(Extended Industry StandardArchitecture,扩展工业标准结构)总线等。所述总线可以分为地址总线、数据总线、控制总线等。为便于表示,图5中仅用一个双向箭头表示,但并不表示仅有一根总线或一种类型的总线。
存储器,用于存放程序。具体地,程序可以包括程序代码,所述程序代码包括计算机操作指令。存储器可以包括内存和非易失性存储器,并向处理器提供指令和数据。
处理器从非易失性存储器中读取对应的计算机程序到内存中然后运行,在逻辑层面上述图3所示的共识节点。处理器,执行存储器所存放的程序,并具体用于执行以下操作:
在接收到区块链的其他共识节点发起的目标共识提议时,基于所述目标共识提议的接收时间,确定第二时间戳,其中,所述目标共识提议携带有所述其他共识节点提供的第一时间戳;
基于本地结尾区块的第三时间戳和所述第二时间戳,对所述第一时间戳进行校验,以在校验通过后对所述目标共识提议的提议数据执行共识逻辑;
若所述目标共识提议达成共识,则生成记录有所述目标共识提议的提议数据的新增区块,其中,生成的所述新增区块的第四时间戳是至少基于所述第一时间戳确定得到的,且不早于本地其他区块的时间戳;
若基于所述区块链的共识协议需要发起共识提议时,发起携带有本地提供的时间戳的共识提议。
上述如本说明书图1所示实施例揭示的区块生成方法可以应用于处理器中,或者由处理器实现。处理器可能是一种集成电路芯片,具有信号的处理能力。在实现过程中,上述方法的各步骤可以通过处理器中的硬件的集成逻辑电路或者软件形式的指令完成。上述的处理器可以是通用处理器,包括中央处理器(Central Processing Unit,CPU)、网络处理器(Network Processor,NP)等;还可以是数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现场可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。可以实现或者执行本说明书实施例中的公开的各方法、步骤及逻辑框图。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。结合本说明书实施例所公开的方法的步骤可以直接体现为硬件译码处理器执行完成,或者用译码处理器中的硬件及软件模块组合执行完成。软件模块可以位于随机存储器,闪存、只读存储器,可编程只读存储器或者电可擦写可编程存储器、寄存器等本领域成熟的存储介质中。该存储介质位于存储器,处理器读取存储器中的信息,结合其硬件完成上述方法的步骤。
应理解,本说明书实施例的电子设备可以实现上述共识节点在图1和图2所示的实施例的功能。由于原理相同,本文不再赘述。
当然,除了软件实现方式之外,本说明书的电子设备并不排除其他实现方式,比如逻辑器件抑或软硬件结合的方式等等,也就是说以下处理流程的执行主体并不限定于各个逻辑单元,也可以是硬件或逻辑器件。
此外,本说明书实施例还提出了一种计算机可读存储介质,该计算机可读存储介质存储一个或多个程序,该一个或多个程序包括指令。其中,当上述指令当被包括多个应用程序的便携式电子设备执行时,能够使该便携式电子设备执行图1所示实施例的区块生成方法,并具体用于执行以下步骤:
在接收到区块链的其他共识节点发起的目标共识提议时,基于所述目标共识提议的接收时间,确定第二时间戳,其中,所述目标共识提议携带有所述其他共识节点提供的第一时间戳;
基于本地结尾区块的第三时间戳和所述第二时间戳,对所述第一时间戳进行校验,以在校验通过后对所述目标共识提议的提议数据执行共识逻辑;
若所述目标共识提议达成共识,则生成记录有所述目标共识提议的提议数据的新增区块,其中,生成的所述新增区块的第四时间戳是至少基于所述第一时间戳确定得到的,且不早于本地其他区块的时间戳;
若基于所述区块链的共识协议需要发起共识提议时,发起携带有本地提供的时间戳的共识提议。
应理解,上述指令当被包括多个应用程序的便携式电子设备执行时,能够使上文所述的共识节点实现图1和图2所示的实施例的功能。由于原理相同,本文不再赘述。
本领域技术人员应明白,本说明书的实施例可提供为方法、系统或计算机程序产品。因此,本说明书可采用完全硬件实施例、完全软件实施例或结合软件和硬件方面的实施例的形式。而且,本说明书可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
上述对本说明书特定实施例进行了描述。其它实施例在所附权利要求书的范围内。在一些情况下,在权利要求书中记载的动作或步骤可以按照不同于实施例中的顺序来执行并且仍然可以实现期望的结果。另外,在附图中描绘的过程不一定要求示出的特定顺序或者连续顺序才能实现期望的结果。在某些实施方式中,多任务处理和并行处理也是可以的或者可能是有利的。
以上仅为本说明书的实施例而已,并不用于限制本说明书。对于本领域技术人员来说,本说明书可以有各种更改和变化。凡在本说明书的精神和原理之内所作的任何修改、等同替换、改进等,均应包含在本说明书的权利要求范围之内。此外,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都应当属于本文件的保护范围。