CN112787849A - 区块链状态的管控方法、装置、终端及存储介质 - Google Patents
区块链状态的管控方法、装置、终端及存储介质 Download PDFInfo
- Publication number
- CN112787849A CN112787849A CN202011576944.5A CN202011576944A CN112787849A CN 112787849 A CN112787849 A CN 112787849A CN 202011576944 A CN202011576944 A CN 202011576944A CN 112787849 A CN112787849 A CN 112787849A
- Authority
- CN
- China
- Prior art keywords
- state
- node
- chain
- link
- final
- 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.)
- Granted
Links
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/08—Configuration management of networks or network elements
- H04L41/0803—Configuration setting
- H04L41/084—Configuration by using pre-existing information, e.g. using templates or copying from other elements
- H04L41/0846—Configuration by using pre-existing information, e.g. using templates or copying from other elements based on copy from other elements
-
- 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/50—Network services
- H04L67/56—Provisioning of proxy services
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本申请适用于区块链技术领域,提供一种区块链状态的管控方法、装置、终端及存储介质,其中方法包括:将区块链平台中的当前链状态输出至用户端;若用户端基于所述当前链状态在所述区块链平台中触发链或链中节点的处理动作,则在所述处理动作处理完毕后,获取所述处理动作中所述节点反馈的节点最终状态;根据所述节点最终状态,基于所述区块链平台中的共识算法,确定所述区块链平台中的最终链状态;将所述区块链平台的当前链状态设置为所述最终链状态。该方案实现对链和节点状态的科学同步,提升区块链平台的状态管控效果。
Description
技术领域
本申请属于区块链技术领域,尤其涉及一种区块链状态的管控方法、装置、终端及存储介质。
背景技术
区块链是一种新型分布式账本,由多个节点组成p2p网络上的链式结构,提供安全可信的数据共享管理服务。区块链作为一种后端服务,同样需要进行生命周期管理。区块链的生命周期管理主要包括创建链、新增节点、启用链和节点、停用链和节点、重启链和节点、删除链和节点。因为区块链生命周期管理针对链和节点这两个彼此关联的对象,所以相对于传统只管理单一对象的后端服务生命周期更复杂。
目前针对区块链本身的生命周期管理方法都较为朴素,或是直接根据区块链和节点的属性来执行相应动作,或是根据当前对链和节点的操作来调整两者的状态。现有区块链状态监控策略将链和节点割裂开来进行分别管控,忽略了链和节点两者间的关联关系,用户在操作节点时,难以及时感知链的变化,区块链状态管控效果不佳。
发明内容
本申请实施例提供了一种区块链状态的管控方法、装置、终端及存储介质,以解决现有技术中区块链状态监控策略将链和节点割裂开来进行分别管控,忽略了链和节点两者间的关联关系,用户在操作节点时,难以及时感知链的变化,区块链状态管控效果不佳的问题。
本申请实施例的第一方面提供了一种区块链状态的管控方法,包括:
将区块链平台中的当前链状态输出至用户端;
若用户端基于所述当前链状态在所述区块链平台中触发链或链中节点的处理动作,则在所述处理动作处理完毕后,获取所述处理动作中所述节点反馈的节点最终状态;
根据所述节点最终状态,基于所述区块链平台中的共识算法,确定所述区块链平台中的最终链状态;
将所述区块链平台的当前链状态设置为所述最终链状态,其中所述最终链状态包括链可用、链不可用、链已删除中的任一项。
本申请实施例的第二方面提供了一种区块链状态的管控装置,包括:
状态输出模块,用于将区块链平台中的当前链状态输出至用户端;
获取模块,用于若用户端基于所述当前链状态在所述区块链平台中触发链或链中节点的处理动作,则在所述处理动作处理完毕后,获取所述处理动作中所述节点反馈的节点最终状态;
确定模块,用于根据所述节点最终状态,基于所述区块链平台中的共识算法,确定所述区块链平台中的最终链状态;
状态设置模块,用于将所述区块链平台的当前链状态设置为所述最终链状态,其中所述最终链状态包括链可用、链不可用、链已删除中的任一项。
本申请实施例的第三方面提供了一种终端,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如第一方面所述方法的步骤。
本申请实施例的第四方面提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时实现如第一方面所述方法的步骤。
本申请的第五方面提供了一种计算机程序产品,当所述计算机程序产品在终端上运行时,使得所述终端执行上述第一方面所述方法的步骤。
由上可见,本申请实施例中,将区块链平台中的当前链状态输出至用户端,若用户端基于当前链状态在区块链平台中触发链或链中节点的处理动作,则在处理动作处理完毕后,获取处理动作中节点反馈的节点最终状态,并根据节点最终状态,基于区块链平台中的共识算法,确定区块链平台中的最终链状态,将区块链平台的当前链状态设置为该最终链状态,该过程引入了链驱动作为根据区块链中节点状态判断链状态的中间件,在区块链的各项处理动作中实现节点状态收集、判断链状态、设置链状态的功能,起到维护链和节点之间关系的作用,实现对链和节点状态的科学同步,可以使用户及时感知节点与链之间状态的协同变化,提升区块链平台的状态管控效果。
附图说明
为了更清楚地说明本申请实施例中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本申请实施例提供的一种区块链状态的管控方法的流程图一;
图2是本申请实施例提供的区块链生命周期管理状态机流程图;
图3是本申请实施例提供的一种区块链状态的管控方法的流程图二;
图4是本申请实施例提供的一种区块链状态的管控装置的结构图;
图5是本申请实施例提供的一种终端的结构图。
具体实施方式
以下描述中,为了说明而不是为了限定,提出了诸如特定***结构、技术之类的具体细节,以便透彻理解本申请实施例。然而,本领域的技术人员应当清楚,在没有这些具体细节的其它实施例中也可以实现本申请。在其它情况中,省略对众所周知的***、装置、电路以及方法的详细说明,以免不必要的细节妨碍本申请的描述。
应当理解,当在本说明书和所附权利要求书中使用时,术语“包括”指示所描述特征、整体、步骤、操作、元素和/或组件的存在,但并不排除一个或多个其它特征、整体、步骤、操作、元素、组件和/或其集合的存在或添加。
还应当理解,在此本申请说明书中所使用的术语仅仅是出于描述特定实施例的目的而并不意在限制本申请。如在本申请说明书和所附权利要求书中所使用的那样,除非上下文清楚地指明其它情况,否则单数形式的“一”、“一个”及“该”意在包括复数形式。
还应当进一步理解,在本申请说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
如在本说明书和所附权利要求书中所使用的那样,术语“如果”可以依据上下文被解释为“当...时”或“一旦”或“响应于确定”或“响应于检测到”。类似地,短语“如果确定”或“如果检测到[所描述条件或事件]”可以依据上下文被解释为意指“一旦确定”或“响应于确定”或“一旦检测到[所描述条件或事件]”或“响应于检测到[所描述条件或事件]”。
具体实现中,本申请实施例中描述的终端包括但不限于诸如具有触摸敏感表面(例如,触摸屏显示器和/或触摸板)的移动电话、膝上型计算机或平板计算机之类的其它便携式设备。还应当理解的是,在某些实施例中,所述设备并非便携式通信设备,而是具有触摸敏感表面(例如,触摸屏显示器和/或触摸板)的台式计算机。
在接下来的讨论中,描述了包括显示器和触摸敏感表面的终端。然而,应当理解的是,终端可以包括诸如物理键盘、鼠标和/或控制杆的一个或多个其它物理用户接口设备。
终端支持各种应用程序,例如以下中的一个或多个:绘图应用程序、演示应用程序、文字处理应用程序、网站创建应用程序、盘刻录应用程序、电子表格应用程序、游戏应用程序、电话应用程序、视频会议应用程序、电子邮件应用程序、即时消息收发应用程序、锻炼支持应用程序、照片管理应用程序、数码相机应用程序、数字摄影机应用程序、web浏览应用程序、数字音乐播放器应用程序和/或数字视频播放器应用程序。
可以在终端上执行的各种应用程序可以使用诸如触摸敏感表面的至少一个公共物理用户接口设备。可以在应用程序之间和/或相应应用程序内调整和/或改变触摸敏感表面的一个或多个功能以及终端上显示的相应信息。这样,终端的公共物理架构(例如,触摸敏感表面)可以支持具有对用户而言直观且透明的用户界面的各种应用程序。
应理解,本实施例中各步骤的序号的大小并不意味着执行顺序的先后,各过程的执行顺序应以其功能和内在逻辑确定,而不应对本申请实施例的实施过程构成任何限定。
为了说明本申请所述的技术方案,下面通过具体实施例来进行说明。
参见图1,图1是本申请实施例提供的一种区块链状态的管控方法的流程图一。如图1所示,一种区块链状态的管控方法,该方法包括以下步骤:
步骤101,将区块链平台中的当前链状态输出至用户端。
当前链状态可以是初始状态、链可用、链不可用、链已删除中的任一项。
其中,在初始状态下,对应于区块链平台中还未建立链的情况,此时可以执行对链的新建操作。链可用状态下,可以对链进行重启、停用、删除等操作。链不可用状态下,可以对链进行删除、启用等操作。
该管控方法通过设定一个链驱动来实现,链驱动是一个根据节点状态判断链状态的中间件,具有收集节点状态、判断链状态、设置链状态的功能,发挥着维护链和节点之间关系的重要作用,以能实现对链和节点状态的科学同步。
具体地,后续过程中对于节点及链的状态的管控,可以通过设置状态机来实现,链驱动则在该状态机基础上,对用户触发的处理动作涉及的改变后的节点状态进行获取,基于该些改变后的节点状态,去设置该些节点所属链的状态。
其中,定义区块链生命周期管理的状态机,状态机是一个有向图,由一组结点和相应的转移函数组成。状态机的结点表示目标对象的状态,并通过响应事件而运行转移函数,并从一个结点进入下一个结点。结合图2所示,为区块链生命周期管理状态机流程图。
区块生命周期管理的状态机具有的状态包括:“初始状态/已有链”、“链可用”、“链处理中”、“链不可用”、“链已删除”、“节点可用”、“节点处理中”、“节点不可用”、“节点已删除”。其中“初始状态/已有链”为起始状态,“链已删除”为终止状态。
具有的事件(也即用户触发***所执行的处理动作)包括:“创建链”、“新增节点”、“停用链”、“重启链”、“启用链”、“删除链”、“停用节点”、“重启节点”、“启用节点”、“删除节点”。这些事件对应不同的状态转移逻辑。
每个状态转移的条件在于***实际运行过程中用户输入参数、***环境变量、运行的软硬件环境,总体将反映在当处于“链处理中”或“节点处理中”时,动作执行是否成功的结果上,该结果对于链来说就是“链可用”或是“链不可用”,对于节点来说就是“节点可用”或是“节点不可用”。链驱动对该些动作是否成功的结果状态进行获取,通过动作执行后的节点状态确定链状态。
步骤102,若用户端基于当前链状态在区块链平台中触发链或链中节点的处理动作,则在处理动作处理完毕后,获取处理动作中节点反馈的节点最终状态。
这里,不同的链状态下,可以赋予用户对不同处理动作的触发。例如,在初始状态下,对应于区块链平台中还未建立链的情况,此时可以执行对链的新建操作。链可用状态下,可以对链进行重启、停用、删除等操作。链不可用状态下,可以对链进行删除、启用等操作。
由于链与节点具有包含与被包含的关系,因此不论是用户触发的对链的处理动作还是对节点的处理动作,都会在处理动作执行后引起节点的状态变化。
通过对处理动作执行后链中节点的最终状态的获取,以获取后续链的状态。
具体地,在链驱动收集节点状态过程中,当某一节点进入“节点可用”、“节点不可用”、“节点已删除”状态后,均会将该状态反馈给链驱动。链驱动将该状态记录到本次动作中该节点的最终状态中。
作为一可选的实施方式,若用户端基于当前链状态在区块链平台中触发链或链中节点的处理动作,则在处理动作处理完毕后,获取处理动作中节点反馈的节点最终状态,包括:
若当前链状态为初始状态,用户端基于该初始状态触发链的创建动作,则在链的创建动作处理完毕后,获取创建的链中所涉及的各个节点被执行创建动作后的节点最终状态。
该节点最终状态包括节点可用、节点不可用、节点已删除中的任一项。
如果***中还未创建链,则认为链状态为初始状态,则可以执行创建链的动作。执行创建链动作后,状态机中该链将进入“链处理中”状态,链中的所有节点将进入“节点处理中”状态。如果链中的某一节点创建成功,则该节点将进入“节点可用”状态,并反馈状态给链驱动;如果创建失败,则进入“节点不可用”状态,并反馈状态给链驱动。
不同地,作为另一可选的实施方式,该若用户端基于当前链状态在区块链平台中触发链或链中节点的处理动作,则在处理动作处理完毕后,获取处理动作中节点反馈的节点最终状态,包括:
若当前链状态为链可用或链不可用状态,用户端基于当前链状态触发链中节点新增动作,则在节点新增动作处理完毕后,获取链中新增节点及链中原有节点的节点最终状态。
其中,节点最终状态包括节点可用、节点不可用、节点已删除中的任一项。
若当前链状态为链可用或链不可用状态说明***中已经存在被创建的链,即处于“已有链”状态,则可以执行在链中新增节点的动作。执行新增节点动作后,状态机中该新增节点将进入“节点处理中”状态,链中已有节点的状态不变。如果节点新增动作处理完毕后,处理结果为节点新增成功,则该节点将进入“节点可用”状态,并反馈处理结果对应的节点状态给链驱动;如果新增失败,则该节点将进入“节点不可用”状态,并反馈处理结果对应的节点状态给链驱动。这里为了后续对链状态进行判断,需要同时获取链中已有节点的节点最终状态。
不同地,作为又一可选的实施方式,该若用户端基于当前链状态在区块链平台中触发链或链中节点的处理动作,则在处理动作处理完毕后,获取处理动作中节点反馈的节点最终状态,包括:
若当前链状态为链可用状态,用户端基于链可用状态触发链的重启或停用动作,则确定链中节点状态为节点可用的第一目标节点,并在链的重启或停用动作处理完毕后,确定第一目标节点执行重启或停用动作后的节点最终状态。
其中,该节点最终状态包括节点可用、节点不可用、节点已删除中的任一项。
当对链进行重启或停用时,具体需要对链中状态为节点可用的目标节点进行对应的重启或停用。
如果***中链处于“链可用”状态,则可以执行停用链或重启链的动作。执行停用链或重启链动作,状态机中链将进入“链处理中”状态,同时状态机设置所有节点进入“节点处理中”状态。将链中节点处于“节点可用”状态的目标节点,对应执行停用节点或重启节点的动作。执行停用节点或重启节点动作,节点将进入“节点处理中”状态。如果某一节点停用成功,该节点将进入“节点不可用”状态,并反馈状态给链驱动;如果停用失败,则进入“节点可用”状态,并反馈状态给链驱动。如果某一节点重启成功,该节点将进入“节点可用”状态,并反馈状态给链驱动;如果重启失败,则进入“节点不可用”状态,并反馈状态给链驱动。
不同地,作为再一可选的实施方式,该若用户端基于当前链状态在区块链平台中触发链或链中节点的处理动作,则在处理动作处理完毕后,获取处理动作中节点反馈的节点最终状态,包括:
若当前链状态为链不可用状态,用户端基于链不可用状态触发链的启用动作,则确定链中节点状态为节点不可用的第二目标节点,并在链的启用动作处理完毕后,确定第二目标节点执行启用动作后的节点最终状态。
其中,节点最终状态包括节点可用、节点不可用、节点已删除中的任一项。
如果***中链处于“链不可用”状态,则可以执行启用链的动作。执行启用链动作,状态机将链设置为“链处理中”状态,并设置所有节点进入“节点处理中”状态。将链中节点处于“节点不可用”状态的目标节点,对应执行启用节点的动作。执行启用节点动作,节点将进入“节点处理中”状态。如果某一节点启用成功,该节点将进入“节点可用”状态,并反馈状态给链驱动;如果该节点启用失败,则进入“节点不可用”状态,并反馈状态给链驱动。
不同地,作为更一可选的实施方式,该若用户端基于当前链状态在区块链平台中触发链或链中节点的处理动作,则在处理动作处理完毕后,获取处理动作中节点反馈的节点最终状态,包括:
若当前链状态为链可用或链不可用状态,用户端基于当前链状态触发链的删除动作,则在链的删除动作处理完毕后,设置链中所涉及的所有节点的节点最终状态为节点已删除状态。
若当前链状态为链可用或链不可用状态说明***中已经存在被创建的链,即处于“已有链”状态,则可以执行删除链的动作。执行删除链动作,同时执行对链中节点的删除节点动作,节点将进入“节点已删除”状态,并反馈状态给链驱动。
步骤103,根据节点最终状态,基于区块链平台中的共识算法,确定区块链平台中的最终链状态。
链驱动收集到节点反馈的状态并结合其他已有节点的状态,根据该区块链的共识算法,判断出链状态是否可用,若可用则设置链状态为“链可用”,否则设置链状态为“链不可用”。
具体地,针对某一动作,当链驱动记录到足够的节点最终状态后(节点的最终状态为“节点可用”、“节点不可用”、“节点已删除”),将根据当前链所具有的共识算法类型,判断出链的最终状态。
如果判断过程中需要利用其他更多关于节点的信息(指除了节点状态之外的信息,比如节点的类型),那么节点在反馈状态时,也需要将这部分信息一并反馈。是否反馈更多信息取决于当前链的共识算法,因此不同链不同共识算法,链驱动的判断过程会不相同。
步骤104,将区块链平台的当前链状态设置为最终链状态。
其中,最终链状态包括链可用、链不可用、链已删除中的任一项。
设置链状态时,针对某一处理动作,当链驱动判断出链的最终状态后,将链的状态设置成最终状态(链的最终状态为“链可用”、“链不可用”、“链已删除”)。
上述过程中,利用状态机,使得区块链生命周期管理的流程连贯清晰,易于维护。如果执行某一动作时失败导致进入“链不可用”或“节点不可用”状态时,可以定时再次执行该动作,重复原状态流程,很容易实现自动恢复等其他功能。且将状态机与链设置节点状态的机制、链驱动这两个技术手段相结合,科学维护链和节点这两个对象之间的关系。当用户操作链时,所有节点能够立刻响应,当用户操作节点时,也能够正确及时地感知链的变化。
本申请实施例中,将区块链平台中的当前链状态输出至用户端,若用户端基于当前链状态在区块链平台中触发链或链中节点的处理动作,则在处理动作处理完毕后,获取处理动作中节点反馈的节点最终状态,并根据节点最终状态,基于区块链平台中的共识算法,确定区块链平台中的最终链状态,将区块链平台的当前链状态设置为该最终链状态,该过程引入了链驱动作为根据区块链中节点状态判断链状态的中间件,在区块链的各项处理动作中实现节点状态收集、判断链状态、设置链状态的功能,起到维护链和节点之间关系的作用,实现对链和节点状态的科学同步,可以使用户及时感知节点与链之间状态的协同变化,提升区块链平台的状态管控效果。
本申请实施例中还提供了区块链状态的管控方法的不同实施方式。
参见图3,图3是本申请实施例提供的一种区块链状态的管控方法的流程图二。如图3所示,一种区块链状态的管控方法,该方法包括以下步骤:
步骤301,将区块链平台中的当前链状态输出至用户端。
该步骤的实现过程与前述实施方式中的步骤101的实现过程相同,此处不再赘述。
步骤302,若用户端基于当前链状态在区块链平台中触发链或链中节点的处理动作,则在处理动作处理完毕后,获取处理动作中节点反馈的节点最终状态。
该步骤的实现过程与前述实施方式中的步骤102的实现过程相同,此处不再赘述。
步骤303,根据节点最终状态,基于区块链平台中的共识算法,判断链中不同的节点最终状态所对应的节点的数量是否大于阈值。
一个链中不同的节点可能会具有不同的节点状态,例如有的处理节点可用状态,有的节点处于节点不可用状态。对不同节点状态的节点数量进行统计,以对包含该些节点的链进行状态判断。
步骤304,若链中节点最终状态为节点可用状态的节点的数量大于第一阈值,则确定区块链平台中的最终链状态为链可用。
将处于节点可用状态的节点的数量进行统计,当其数量大于阈值时,则确定链状态为链可用。
步骤305,若链中节点最终状态为节点不可用状态的节点的数量大于第二阈值,则确定区块链平台中的最终链状态为链不可用。
将处于节点不可用状态的节点的数量进行统计,当其数量大于阈值时,则确定链状态为链不可用。
步骤306,若链中节点最终状态为节点已删除的节点的数量大于第三阈值,则确定区块链平台中的最终链状态为链已删除。
该第三阈值例如为链中的全部节点数量值减1。
步骤307,将区块链平台的当前链状态设置为最终链状态。
该步骤的实现过程与前述实施方式中的步骤104的实现过程相同,此处不再赘述。
下面对上述过程以***处于初始状态,执行创建链这一处理动作为例,进行实例说明。
用户触发***执行创建链的动作。所需创建的链为Hyperchain,采用RBFT(Redundant Byzantine Fault Tolerance,冗余拜占庭容错)共识算法,创建4个VP类型的节点以组成1条链;状态机将该链设置为“链处理中”状态,将4个VP节点设置成“节点处理中”状态;***按照用户需要在指定主机上安装Hyperchain的4个VP节点。对于某一节点,如果安装过程顺利执行,节点创建成功,则***将该节点设置为“节点可用”状态,并通过HTTP请求将节点状态发送给链驱动;如果安装过程出现错误,节点创建失败,则***将该节点设置为“节点不可用”状态,并通过HTTP请求将节点状态发送给链驱动。假设本次安装时,有3个节点创建成功,进入“节点可用”状态,有1个节点创建失败,进入“节点不可用”状态。
当链驱动依次接收到所有4个节点反馈的状态后(即3个节点可用,1个节点不可用),根据该区块链的共识算法判断链状态。该区块链Hyperchain的RBFT共识算法要求:当可用的VP节点个数大于等于总节点个数的3/4时,链才可用;否则链不可用。那么此例中,总节点个数为4,可用VP节点个数为3,满足要求,因此链驱动判断当前链可用。链驱动设置链状态为“链可用”。创建链的动作执行结束。
本申请实施例中,将区块链平台中的当前链状态输出至用户端,若用户端基于当前链状态在区块链平台中触发链或链中节点的处理动作,则在处理动作处理完毕后,获取处理动作中节点反馈的节点最终状态,并根据节点最终状态,基于区块链平台中的共识算法,判断链中不同的节点最终状态所对应的节点的数量与阈值的大小关系,来确定区块链平台中的最终链状态,将区块链平台的当前链状态设置为该最终链状态,该过程引入了链驱动作为根据区块链中节点状态判断链状态的中间件,在区块链的各项处理动作中实现节点状态收集、判断链状态、设置链状态的功能,起到维护链和节点之间关系的作用,实现对链和节点状态的科学同步,可以使用户及时感知节点与链之间状态的协同变化,提升区块链平台的状态管控效果。
参见图4,图4是本申请实施例提供的一种区块链状态的管控装置的结构图,为了便于说明,仅示出了与本申请实施例相关的部分。
所述区块链状态的管控装置400包括:
状态输出模块401,用于将区块链平台中的当前链状态输出至用户端;
获取模块402,用于若用户端基于所述当前链状态在所述区块链平台中触发链或链中节点的处理动作,则在所述处理动作处理完毕后,获取所述处理动作中所述节点反馈的节点最终状态;
确定模块403,用于根据所述节点最终状态,基于所述区块链平台中的共识算法,确定所述区块链平台中的最终链状态;
状态设置模块404,用于将所述区块链平台的当前链状态设置为所述最终链状态,其中所述最终链状态包括链可用、链不可用、链已删除中的任一项。
其中,获取模块402,具体用于:
若所述当前链状态为初始状态,所述用户端基于所述初始状态触发链的创建动作,则在所述链的创建动作处理完毕后,获取创建的所述链中所涉及的各个节点被执行创建动作后的节点最终状态,所述节点最终状态包括节点可用、节点不可用、节点已删除中的任一项。
其中,获取模块402,具体用于:
若所述当前链状态为链可用或链不可用状态,所述用户端基于所述当前链状态触发链中节点新增动作,则在所述节点新增动作处理完毕后,获取所述链中新增节点及所述链中原有节点的节点最终状态,所述节点最终状态包括节点可用、节点不可用、节点已删除中的任一项。
其中,获取模块402,具体用于:
若所述当前链状态为链可用状态,所述用户端基于所述链可用状态触发链的重启或停用动作,则确定所述链中节点状态为节点可用的第一目标节点,并在所述链的重启或停用动作处理完毕后,确定所述第一目标节点执行重启或停用动作后的节点最终状态,所述节点最终状态包括节点可用、节点不可用、节点已删除中的任一项。
其中,获取模块402,具体用于:
若所述当前链状态为链不可用状态,所述用户端基于所述链不可用状态触发链的启用动作,则确定所述链中节点状态为节点不可用的第二目标节点,并在所述链的启用动作处理完毕后,确定所述第二目标节点执行启用动作后的节点最终状态,所述节点最终状态包括节点可用、节点不可用、节点已删除中的任一项。
其中,获取模块402,具体用于:
若所述当前链状态为链可用或链不可用状态,所述用户端基于所述当前链状态触发链的删除动作,则在所述链的删除动作处理完毕后,设置所述链中所涉及的所有节点的节点最终状态为节点已删除状态。
确定模块403,具体用于:
根据所述节点最终状态,基于所述区块链平台中的共识算法,判断所述链中不同的所述节点最终状态所对应的节点的数量是否大于阈值;
若所述链中所述节点最终状态为节点可用状态的节点的数量大于第一阈值,则确定所述区块链平台中的最终链状态为链可用;
若所述链中所述节点最终状态为节点不可用状态的节点的数量大于第二阈值,则确定所述区块链平台中的最终链状态为链不可用;
若所述链中所述节点最终状态为节点已删除的节点的数量大于第三阈值,则确定所述区块链平台中的最终链状态为链已删除。
本申请实施例提供的区块链状态的管控装置能够实现上述区块链状态的管控方法的实施例的各个过程,且能达到相同的技术效果,为避免重复,这里不再赘述。
图5是本申请实施例提供的一种终端的结构图。如该图所示,该实施例的终端5包括:至少一个处理器50(图5中仅示出一个)、存储器51以及存储在所述存储器51中并可在所述至少一个处理器50上运行的计算机程序52,所述处理器50执行所述计算机程序52时实现上述任意各个方法实施例中的步骤。
所述终端5可以是桌上型计算机、笔记本、掌上电脑及云端服务器等计算设备。所述终端5可包括,但不仅限于,处理器50、存储器51。本领域技术人员可以理解,图5仅仅是终端5的示例,并不构成对终端5的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件,例如所述终端还可以包括输入输出设备、网络接入设备、总线等。
所述处理器50可以是中央处理单元(Central Processing Unit,CPU),还可以是其他通用处理器、数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现场可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
所述存储器51可以是所述终端5的内部存储单元,例如终端5的硬盘或内存。所述存储器51也可以是所述终端5的外部存储设备,例如所述终端5上配备的插接式硬盘,智能存储卡(Smart Media Card,SMC),安全数字(Secure Digital,SD)卡,闪存卡(Flash Card)等。进一步地,所述存储器51还可以既包括所述终端5的内部存储单元也包括外部存储设备。所述存储器51用于存储所述计算机程序以及所述终端所需的其他程序和数据。所述存储器51还可以用于暂时地存储已经输出或者将要输出的数据。
所属领域的技术人员可以清楚地了解到,为了描述的方便和简洁,仅以上述各功能单元、模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能单元、模块完成,即将所述装置的内部结构划分成不同的功能单元或模块,以完成以上描述的全部或者部分功能。实施例中的各功能单元、模块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中,上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。另外,各功能单元、模块的具体名称也只是为了便于相互区分,并不用于限制本申请的保护范围。上述***中单元、模块的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述或记载的部分,可以参见其它实施例的相关描述。
本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、或者计算机软件和电子硬件的结合来实现。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本申请的范围。
在本申请所提供的实施例中,应该理解到,所揭露的装置/终端和方法,可以通过其它的方式实现。例如,以上所描述的装置/终端实施例仅仅是示意性的,例如,所述模块或单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个***,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通讯连接可以是通过一些接口,装置或单元的间接耦合或通讯连接,可以是电性,机械或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本申请各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
所述集成的模块/单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请实现上述实施例方法中的全部或部分流程,也可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一计算机可读存储介质中,该计算机程序在被处理器执行时,可实现上述各个方法实施例的步骤。其中,所述计算机程序包括计算机程序代码,所述计算机程序代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。所述计算机可读介质可以包括:能够携带所述计算机程序代码的任何实体或装置、记录介质、U盘、移动硬盘、磁碟、光盘、计算机存储器、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、电载波信号、电信信号以及软件分发介质等。需要说明的是,所述计算机可读介质包含的内容可以根据司法管辖区内立法和专利实践的要求进行适当的增减,例如在某些司法管辖区,根据立法和专利实践,计算机可读介质不包括电载波信号和电信信号。
本申请实现上述实施例方法中的全部或部分流程,也可以通过计算机程序产品来实现,当计算机程序产品在终端上运行时,使得所述终端执行时实现可实现上述各个方法实施例中的步骤。
以上所述实施例仅用以说明本申请的技术方案,而非对其限制;尽管参照前述实施例对本申请进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本申请各实施例技术方案的精神和范围,均应包含在本申请的保护范围之内。
Claims (10)
1.一种区块链状态的管控方法,其特征在于,包括:
将区块链平台中的当前链状态输出至用户端;
若用户端基于所述当前链状态在所述区块链平台中触发链或链中节点的处理动作,则在所述处理动作处理完毕后,获取所述处理动作中所述节点反馈的节点最终状态;
根据所述节点最终状态,基于所述区块链平台中的共识算法,确定所述区块链平台中的最终链状态;
将所述区块链平台的当前链状态设置为所述最终链状态,其中所述最终链状态包括链可用、链不可用、链已删除中的任一项。
2.根据权利要求1所述的管控方法,其特征在于,所述若用户端基于所述当前链状态在所述区块链平台中触发链或链中节点的处理动作,则在所述处理动作处理完毕后,获取所述处理动作中所述节点反馈的节点最终状态,包括:
若所述当前链状态为初始状态,所述用户端基于所述初始状态触发链的创建动作,则在所述链的创建动作处理完毕后,获取创建的所述链中所涉及的各个节点被执行创建动作后的节点最终状态,所述节点最终状态包括节点可用、节点不可用、节点已删除中的任一项。
3.根据权利要求1所述的管控方法,其特征在于,所述若用户端基于所述当前链状态在所述区块链平台中触发链或链中节点的处理动作,则在所述处理动作处理完毕后,获取所述处理动作中所述节点反馈的节点最终状态,包括:
若所述当前链状态为链可用或链不可用状态,所述用户端基于所述当前链状态触发链中节点新增动作,则在所述节点新增动作处理完毕后,获取所述链中新增节点及所述链中原有节点的节点最终状态,所述节点最终状态包括节点可用、节点不可用、节点已删除中的任一项。
4.根据权利要求1所述的管控方法,其特征在于,所述若用户端基于所述当前链状态在所述区块链平台中触发链或链中节点的处理动作,则在所述处理动作处理完毕后,获取所述处理动作中所述节点反馈的节点最终状态,包括:
若所述当前链状态为链可用状态,所述用户端基于所述链可用状态触发链的重启或停用动作,则确定所述链中节点状态为节点可用的第一目标节点,并在所述链的重启或停用动作处理完毕后,确定所述第一目标节点执行重启或停用动作后的节点最终状态,所述节点最终状态包括节点可用、节点不可用、节点已删除中的任一项。
5.根据权利要求1所述的管控方法,其特征在于,所述若用户端基于所述当前链状态在所述区块链平台中触发链或链中节点的处理动作,则在所述处理动作处理完毕后,获取所述处理动作中所述节点反馈的节点最终状态,包括:
若所述当前链状态为链不可用状态,所述用户端基于所述链不可用状态触发链的启用动作,则确定所述链中节点状态为节点不可用的第二目标节点,并在所述链的启用动作处理完毕后,确定所述第二目标节点执行启用动作后的节点最终状态,所述节点最终状态包括节点可用、节点不可用、节点已删除中的任一项。
6.根据权利要求1所述的管控方法,其特征在于,所述若用户端基于所述当前链状态在所述区块链平台中触发链或链中节点的处理动作,则在所述处理动作处理完毕后,获取所述处理动作中所述节点反馈的节点最终状态,包括:
若所述当前链状态为链可用或链不可用状态,所述用户端基于所述当前链状态触发链的删除动作,则在所述链的删除动作处理完毕后,设置所述链中所涉及的所有节点的节点最终状态为节点已删除状态。
7.根据权利要求1-6任一项所述的管控方法,其特征在于,所述根据所述节点最终状态,基于所述区块链平台中的共识算法,确定所述区块链平台中的最终链状态,包括:
根据所述节点最终状态,基于所述区块链平台中的共识算法,判断所述链中不同的所述节点最终状态所对应的节点的数量是否大于阈值;
若所述链中所述节点最终状态为节点可用状态的节点的数量大于第一阈值,则确定所述区块链平台中的最终链状态为链可用;
若所述链中所述节点最终状态为节点不可用状态的节点的数量大于第二阈值,则确定所述区块链平台中的最终链状态为链不可用;
若所述链中所述节点最终状态为节点已删除的节点的数量大于第三阈值,则确定所述区块链平台中的最终链状态为链已删除。
8.一种区块链状态的管控装置,其特征在于,包括:
状态输出模块,用于将区块链平台中的当前链状态输出至用户端;
获取模块,用于若用户端基于所述当前链状态在所述区块链平台中触发链或链中节点的处理动作,则在所述处理动作处理完毕后,获取所述处理动作中所述节点反馈的节点最终状态;
确定模块,用于根据所述节点最终状态,基于所述区块链平台中的共识算法,确定所述区块链平台中的最终链状态;
状态设置模块,用于将所述区块链平台的当前链状态设置为所述最终链状态,其中所述最终链状态包括链可用、链不可用、链已删除中的任一项。
9.一种终端,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求1至7任一项所述方法的步骤。
10.一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至7任一项所述方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011576944.5A CN112787849B (zh) | 2020-12-28 | 2020-12-28 | 区块链状态的管控方法、装置、终端及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011576944.5A CN112787849B (zh) | 2020-12-28 | 2020-12-28 | 区块链状态的管控方法、装置、终端及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN112787849A true CN112787849A (zh) | 2021-05-11 |
CN112787849B CN112787849B (zh) | 2022-05-24 |
Family
ID=75752778
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202011576944.5A Active CN112787849B (zh) | 2020-12-28 | 2020-12-28 | 区块链状态的管控方法、装置、终端及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112787849B (zh) |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108134819A (zh) * | 2017-12-06 | 2018-06-08 | 北京连琪科技有限公司 | 区块链运行状态收集及传送方法、装置及服务器 |
CN110149316A (zh) * | 2019-04-22 | 2019-08-20 | 众安信息技术服务有限公司 | 一种区块链的发布方法及装置 |
WO2019179538A2 (en) * | 2019-07-11 | 2019-09-26 | Alibaba Group Holding Limited | Shared blockchain data storage |
CN110458538A (zh) * | 2019-07-31 | 2019-11-15 | 阿里巴巴集团控股有限公司 | 基于区块链的状态机维护方法及装置、电子设备、存储介质 |
CN111355780A (zh) * | 2020-02-18 | 2020-06-30 | 杭州云象网络技术有限公司 | 一种基于区块链的物联网监控管理方法及*** |
-
2020
- 2020-12-28 CN CN202011576944.5A patent/CN112787849B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108134819A (zh) * | 2017-12-06 | 2018-06-08 | 北京连琪科技有限公司 | 区块链运行状态收集及传送方法、装置及服务器 |
CN110149316A (zh) * | 2019-04-22 | 2019-08-20 | 众安信息技术服务有限公司 | 一种区块链的发布方法及装置 |
WO2019179538A2 (en) * | 2019-07-11 | 2019-09-26 | Alibaba Group Holding Limited | Shared blockchain data storage |
CN110458538A (zh) * | 2019-07-31 | 2019-11-15 | 阿里巴巴集团控股有限公司 | 基于区块链的状态机维护方法及装置、电子设备、存储介质 |
CN111355780A (zh) * | 2020-02-18 | 2020-06-30 | 杭州云象网络技术有限公司 | 一种基于区块链的物联网监控管理方法及*** |
Also Published As
Publication number | Publication date |
---|---|
CN112787849B (zh) | 2022-05-24 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
WO2018049888A1 (zh) | 应用数据的迁移方法及装置 | |
KR20120037397A (ko) | 카탈로그-기반 소프트웨어 컴포넌트 관리 | |
CN109445861A (zh) | ***启动方法、装置、计算机装置及存储介质 | |
CN110244963B (zh) | 数据更新方法、装置及终端设备 | |
CN112612853A (zh) | 基于数据库集群的数据处理方法、装置及电子设备 | |
EP3497586A1 (en) | Discovery of calling application for control of file hydration behavior | |
CN112698793B (zh) | 一种数据存储方法、装置、机器可读介质及设备 | |
US9727394B2 (en) | Establishing causality order of computer trace records | |
CN111767270A (zh) | 数据迁移方法、装置、服务器及存储介质 | |
US11552840B2 (en) | Intention-based device component tracking system | |
US20130246347A1 (en) | Database file groups | |
CN106775445B (zh) | 数据迁移方法及装置 | |
CN112787849B (zh) | 区块链状态的管控方法、装置、终端及存储介质 | |
CN109445909A (zh) | 虚拟机数据的备份方法、***、终端及存储介质 | |
CN117270891A (zh) | 一种蓝牙耳机的固件烧录方法、装置、终端及存储介质 | |
CN111193804B (zh) | 分布式存储方法及装置、网络节点及存储介质 | |
CN116208487A (zh) | 区块链***中的共识算法升级方法、装置、设备及介质 | |
US20230385164A1 (en) | Systems and Methods for Disaster Recovery for Edge Devices | |
CN111130856A (zh) | 一种服务器配置方法、***、设备及计算机可读存储介质 | |
CN111078418A (zh) | 操作同步方法、装置、电子设备及计算机可读存储介质 | |
CN108632366B (zh) | 文件下载方法、装置及终端设备 | |
CN108459942A (zh) | 一种数据处理方法、装置及存储介质 | |
CN113656378A (zh) | 一种服务器管理方法、装置、介质 | |
CN112912848A (zh) | 一种丛集作业过程中的电源请求管理方法 | |
CN107209882B (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 |