CN113282463A - 一种矿工节点确定方法及装置 - Google Patents
一种矿工节点确定方法及装置 Download PDFInfo
- Publication number
- CN113282463A CN113282463A CN202110631397.4A CN202110631397A CN113282463A CN 113282463 A CN113282463 A CN 113282463A CN 202110631397 A CN202110631397 A CN 202110631397A CN 113282463 A CN113282463 A CN 113282463A
- Authority
- CN
- China
- Prior art keywords
- node
- nodes
- miner
- preset
- target
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
- 238000000034 method Methods 0.000 title claims abstract description 42
- 230000004044 response Effects 0.000 claims abstract description 40
- 238000012790 confirmation Methods 0.000 claims abstract description 21
- 230000001960 triggered effect Effects 0.000 claims abstract description 11
- 230000002159 abnormal effect Effects 0.000 claims description 3
- 238000004891 communication Methods 0.000 description 15
- 238000004590 computer program Methods 0.000 description 9
- 238000010586 diagram Methods 0.000 description 8
- 230000008569 process Effects 0.000 description 7
- 238000004422 calculation algorithm Methods 0.000 description 4
- 230000005856 abnormality Effects 0.000 description 3
- 230000009471 action Effects 0.000 description 3
- 238000005516 engineering process Methods 0.000 description 3
- 230000007246 mechanism Effects 0.000 description 3
- 238000004458 analytical method Methods 0.000 description 2
- 230000006870 function Effects 0.000 description 2
- 238000012545 processing Methods 0.000 description 2
- 238000004088 simulation Methods 0.000 description 2
- 238000012360 testing method Methods 0.000 description 2
- 238000003491 array Methods 0.000 description 1
- 238000013475 authorization Methods 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 230000001186 cumulative effect Effects 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 239000000835 fiber Substances 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 238000007726 management method Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 238000007619 statistical method Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3003—Monitoring arrangements specially adapted to the computing system or computing system component being monitored
- G06F11/3006—Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system is distributed, e.g. networked systems, clusters, multiprocessor systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3065—Monitoring arrangements determined by the means or processing involved in reporting the monitored data
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- Computing Systems (AREA)
- Quality & Reliability (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Mathematical Physics (AREA)
- Financial Or Insurance-Related Operations Such As Payment And Settlement (AREA)
Abstract
本发明实施例提供了一种矿工节点确定方法及装置,涉及区块链技术领域,上述方法包括:根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,从区块链系统包含的各节点中选择第一预设数量个目标节点,并将接收到用户触发的矿工竞选指示的目标节点确定为备选节点;在所述备选节点向各目标节点发送矿工竞选请求后,根据各备选节点所接收的确认响应的数量,从各备选节点中确定矿工节点,其中,所述确认响应为:目标节点针对所述矿工竞选请求生成的响应。应用本实施例提供的方案能够实现确定区块链系统中的矿工节点。
Description
技术领域
本发明涉及区块链技术领域,特别是涉及一种矿工节点确定方法及装置。
背景技术
区块链技术作为一项新兴的创新技术,集结了分布式系统、共识算法、密码学、通信网络等众多技术的创新之处。从本质上来说,区块链是一种去中心化的分布式数据库,区块链包含的各节点中存储了区块链的所有数据。
区块链的各节点中包含能够生成区块的节点,将这些节点称为矿工节点。具体的,在区块链的系统中产生新数据时,矿工节点可以对新数据进行打包,生成区块,并将生成的区块添加至区块链中。矿工节点对于区块链的重要性较高,如何确定矿工节点成为一个亟需待解决的问题。
发明内容
本发明实施例的目的在于提供一种矿工节点确定方法及装置,以解决确定矿工节点的问题。具体技术方案如下:
第一方面,本发明实施例提供了一种矿工节点确定方法,所述方法包括:
根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,从区块链系统包含的各节点中选择第一预设数量个目标节点,并将接收到用户触发的矿工竞选指示的目标节点确定为备选节点,其中,所述第一预设数量为:基于预设的故障节点数量计算得到的数量,所述预设的故障节点数量为:所述区块链系统中发生故障的故障节点的数量统计值;
在所述备选节点向各目标节点发送矿工竞选请求后,根据各备选节点所接收的确认响应的数量,从各备选节点中确定矿工节点,其中,所述确认响应为:目标节点针对所述矿工竞选请求生成的响应。
本发明的一个实施例中,上述根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,从区块链系统包含的各节点中选择第一预设数量个目标节点,包括:
根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,计算各节点的权重,将第一预设数量个权重最高的节点确定为目标节点。
本发明的一个实施例中,上述根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,计算各节点的权重,包括:
按照以下表达式计算节点的权重Stock:
Stock=coinTime*Alpha+coinNum*Beta
其中,coinTime表示节点曾被选中为矿工节点的时长,coinNum表示节点曾被选中为矿工节点的次数,Alpha为第一预设系数,Beta为第二预设系数。
本发明的一个实施例中,上述第一预设数量为按照以下表达式计算得到的数量N:
N=af+b
其中,f表示所述预设的故障节点数量,a表示第三预设系数,a>2,且a为整数,b表示预设常数。
本发明的一个实施例中,上述方法还包括:
统计各备选节点所接收的确认响应的数量之和;
若统计得到的和值小于或者等于第二预设数量,生成表征所述区块链系统异常的告警信息,并将所述告警信息添加至所述矿工节点生成的区块中,其中,所述第二预设数量为:所述第一预设数量与所述预设的故障节点数量之差。
本发明的一个实施例中,上述根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,从区块链系统包含的各节点中选择第一预设数量个目标节点,包括:
按照预设时间间隔,根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,从区块链系统包含的各节点中选择第一预设数量个目标节点,其中,所述预设时间间隔为:基于所述第一预设数量以及区块生成时长计算得到的时间间隔。
第二方面,本发明实施例提供了一种矿工节点确定装置,所述装置包括:
备选节点确定模块,用于根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,从区块链系统包含的各节点中选择第一预设数量个目标节点,并将接收到用户触发的矿工竞选指示的目标节点确定为备选节点,其中,所述第一预设数量为:基于预设的故障节点数量计算得到的数量,所述预设的故障节点数量为:所述区块链系统中发生故障的故障节点的数量统计值;
矿工节点确定模块,用于在所述备选节点向各目标节点发送矿工竞选请求后,根据各备选节点所接收的确认响应的数量,从各备选节点中确定矿工节点,其中,所述确认响应为:目标节点针对所述矿工竞选请求生成的响应。
本发明的一个实施例中,上述备选节点确定模块,包括:
目标节点确定子模块,用于根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,计算各节点的权重,将第一预设数量个权重最高的节点确定为目标节点;
备选节点确定子模块,用于将接收到用户触发的矿工竞选指示的目标节点确定为备选节点。
本发明的一个实施例中,上述目标节点确定子模块,具体用于按照以下表达式计算节点的权重Stock:
Stock=coinTime*Alpha+coinNum*Beta
其中,coinTime表示节点曾被选中为矿工节点的时长,coinNum表示节点曾被选中为矿工节点的次数,Alpha为第一预设系数,Beta为第二预设系数。
本发明的一个实施例中,上述第一预设数量为按照以下表达式计算得到的数量N:
N=af+b
其中,f表示所述预设的故障节点数量,a表示第三预设系数,a>2,且a为整数,b表示预设常数。
本发明的一个实施例中,上述装置还包括:
数量统计模块,用于统计各备选节点所接收的确认响应的数量之和;
信息生成模块,用于若统计得到的和值小于或者等于第二预设数量,生成表征所述区块链系统异常的告警信息,并将所述告警信息添加至所述矿工节点生成的区块中,其中,所述第二预设数量为:所述第一预设数量与所述预设的故障节点数量之差。
本发明的一个实施例中,上述备选节点确定模块,具体用于按照预设时间间隔,根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,从区块链系统包含的各节点中选择第一预设数量个目标节点,其中,所述预设时间间隔为:基于所述第一预设数量以及区块生成时长计算得到的时间间隔。
第三方面,本发明实施例提供了一种网络设备,包括处理器、通信接口、存储器和通信总线,其中,处理器,通信接口,存储器通过通信总线完成相互间的通信;
存储器,用于存放计算机程序;
处理器,用于执行存储器上所存放的程序时,实现上述第一方面所述的方法步骤。
第四方面,本发明实施例提供了一种计算机可读存储介质,所述计算机可读存储介质内存储有计算机程序,所述计算机程序被处理器执行时实现上述第一方面所述的方法步骤。
由以上可见,应用本发明实施例提供的方案确定矿工节点时,从区块链系统包含的各节点中选择第一预设数量个目标节点,也就是目标节点的数量小于区块链系统包含的节点数量,从数量较少的目标节点中选择矿工节点,能够提高矿工节点确定的效率。
并且,由于是根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长选择目标节点,且各节点曾被选中为矿工节点的次数以及时长能够反映该节点具备成为矿工节点的所需性能程度,因此,基于各节点对应的次数以及时长能够准确选择目标节点,进而能够提高提高矿工节点确定的准确度。
另外,上述第一预设数量是基于区块链系统中发生故障的故障节点的数量统计值所确定的,上述统计值故障节点数量用于表征区块链系统正常运行时能够容纳的故障节点的数量,也就是上述的第一预设数量与区块链系统正常运行时能够容纳的故障节点的数量相关联,在从选择的第一预设数量个目标节点中选择备选节点时,即使区块链系统中出现故障节点,依然能够确定矿工节点,进一步提高了确定矿工节点的效率以及容错率。
当然,实施本发明的任一产品或方法并不一定需要同时达到以上所述的所有优点。
附图说明
为了更清楚地说明本申请实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,还可以根据这些附图获得其他的实施例。
图1为本发明实施例提供的一种矿工节点确定方法的流程示意图;
图2为本发明实施例提供的一种节点关系的示意图;
图3a为本发明实施例提供的一种交易量仿真图;
图3b为本发明实施例提供的一种交易量对比图;
图4为本发明实施例提供的一种矿工节点确定装置的结构示意图;
图5为本发明实施例提供的一种网络设备的结构示意图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员基于本申请所获得的所有其他实施例,都属于本发明保护的范围。
以下对本发明实施例的执行主体进行说明。
本发明实施例的执行主体为区块链系统中包含的节点,节点不仅用于对数据进行处理,还具有管理功能。
参见图1,图1为本发明实施例提供的一种矿工节点方法的流程示意图,上述方法包括以下步骤S101-S102。
步骤S101:根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,从区块链系统包含的各节点中选择第一预设数量个目标节点,并将接收到用户触发的矿工竞选指示的目标节点确定为备选节点。
节点曾被选中为矿工节点的时长可以通过区块生成时长和被选中为矿工节点的次数计算得到。例如:假设节点曾经3次被选中为矿工节点,且区块生成时长为1ms,可以计算得到该节点被选中为矿工节点的时长为:3*1ms=3ms。
具体的,各节点对应的次数和时长可以是记录各节点中。
在区块链系统中,被选中为矿工节点的节点可以获得代币奖励,可以将节点所持有的代币的数量表征为该节点曾被选中为矿工节点的次数,并将该节点所持有的的代币的时长表征为该节点曾被选中为矿工节点的时长。
第一预设数量为:基于预设的故障节点数量计算得到的数量。
故障节点数量为:区块链系统中发生故障的故障节点的数量统计值。数量统计值可以是:平均值、最大值等。故障节点数量用于表征区块链系统正常运行时能够容纳的故障节点的数量。
在选择第一预设数量个目标节点时,本发明的一个实施例中,可以根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,计算各节点的权重,将第一预设数量个权重最高的节点确定为目标节点将各节点对应的次数和时长。
具体的,可以采用以下表达式计算节点的权重Stock:
Stock=coinTime*Alpha+coinNum*Beta
其中,coinTime表示节点曾被选中为矿工节点的时长,coinNum表示节点曾被选中为矿工节点的次数,Alpha为第一预设系数,Beta为第二预设系数。
第一预设系数和第二预设系数可以由工作人员根据经验预先确定的,还可以由工作人员预先确定第一预设系数与第二预设系数之间的比值,如可以预先设定比值为3:7。
当采用节点所持有的代币的数量表征为该节点曾被选中为矿工节点的次数时,coinNum又可以表示节点所持有的代币的数量;当采用该节点所持有的的代币的时长表征为该节点曾被选中为矿工节点的时长时,coinTime又可以表示节点所持有的代币的时长。
在选择第一预设数量个目标节点时,还可以直接计算各节点对应的次数以及时长之和,将第一预设数量个和值最高的节点作为目标节点。
由于上述目标节点是基于节点历史被选中为矿工节点的次数以及时长选择得到的,也就是所选择的目标节点是具备矿工节点的生成区块的能力的。
用户可以在用户界面触发矿工竞选指示,上述矿工竞选指示用于指示用户对应的节点竞选矿工,上述节点接收到矿工竞选指示后,表示该节点需要竞选矿工。所以将目标节点中接收到用户触发的矿工竞选指示的目标节点确定为备选节点,以从备选节点中选择出矿工节点。
步骤S102:在备选节点向各目标节点发送矿工竞选请求后,根据各备选节点所接收的确认响应的数量,从各备选节点中确定矿工节点。
上述确认响应为:目标节点针对矿工竞选请求生成的响应。
备选节点向各目标节点发送矿工竞选请求到接收到目标节点发送的确认响应这个过程中,经历两个阶段,包括提议阶段和确认阶段:
在提议阶段中,备选节点需要向各目标节点发送矿工竞选请求,矿工竞选请求中可以携带备选节点的标识,备选节点的标识可以是随机生成、且各备选节点的标识具有唯一性;还可以携带备选节点的标识以及提议值,提议值也可以是随机生成的;
在确认阶段,目标节点根据接收各矿工竞选请求的接收时刻、各矿工竞选请求中携带的信息,确定向哪一备选节点发送确认响应,并向所确定的备选节点发送确认响应。
具体实现过程可以参见现有技术中任意一种实现方式,在此不进行详述。
当备选节点接收到大多数目标节点发送的确认响应,备选节点接收到的确认响应数量较多,表示大多数目标节点同意该节点可以作为矿工节点;当备选节点接收到少数目标节点发送的确认响应,备选节点接收到的确认响应数量较少,表示只有少数目标节点同意该节点可以作为矿工节点。基于少数服从多数的原则,可以将大多数目标节点所同意的节点确定为矿工节点。
通过上述分析可知,在确定矿工节点时,可以将接收的确认响应的数量最高的节点,确定为矿工节点。
还可以将接收的确认响应的数量为预设响应数量的节点,确定为矿工节点,上述预设响应数量可以是对历史矿工节点所街收到的确认响应数量统计分析得到的,如计算平均值、最大值等分析方式。
由以上可见,应用本实施例提供的方案确定矿工节点时,从区块链系统包含的各节点中选择第一预设数量个目标节点,也就是目标节点的数量小于区块链系统包含的节点数量,从数量较少的目标节点中选择矿工节点,能够提高矿工节点确定的效率。
并且,由于是根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长选择目标节点,且各节点曾被选中为矿工节点的次数以及时长能够反映该节点具备成为矿工节点的所需性能程度,因此,基于各节点对应的次数以及时长能够准确选择目标节点,进而能够提高提高矿工节点确定的准确度。
另外,上述第一预设数量是基于区块链系统中发生故障的故障节点的数量统计值所确定的,上述统计值故障节点数量用于表征区块链系统正常运行时能够容纳的故障节点的数量,也就是上述的第一预设数量与区块链系统正常运行时能够容纳的故障节点的数量相关联,在从选择的第一预设数量个目标节点中选择备选节点时,即使区块链系统中出现故障节点,依然能够确定矿工节点,进一步提高了确定矿工节点的效率以及容错率。
本发明的一个实施例中,步骤S101中提及的第一预设数量N可以按照以下表达式计算得到。
N=af+b
其中,f表示预设的故障节点数量,a表示第三预设系数,a>2,且a为整数,b表示预设常数。
上述a可以取值为3,b可以取值为1。
本发明的一个实施例中,还可以统计各备选节点所接收的确认响应的数量之和;若统计得到的和值小于或者等于第二预设数量,生成表征区块链系统异常的告警信息,并将告警信息添加至矿工节点生成的区块中。
上述第二预设数量为:第一预设数量与预设的故障节点数量之差。例如:假设第一预设数量为:3f+1,预设的故障节点数量为f,第二预设数量为:(3f+1)-f=2f+1。
具体的,可以将告警信息添加至区块的预设位置处,如添加至区块的头部位置处。
当所统计的各备选节点所接收的确认响应的数量之和大于第二预设数量时,表示当前区块链系统中出现故障的节点的数量为可容纳故障节点数量的范围内;当所统计的各备选节点所接收的确认响应的数量之和小于或者等于第二预设数量时,表示当前区块链系统中出现故障的节点的数量超出可容纳故障节点数量的范围内,也就是区块链系统中可能出现异常,在这种情况下,将表征区块链系统异常的告警信息添加至所生成的区块中,用于提示区块链系统中各区块当前区块链系统可能发生故障、异常等情况。
本发明的一个实施例中,在上述步骤S101中选择目标节点时,可以按照预设时间间隔,根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,从区块链系统包含的各节点中选择第一预设数量个目标节点。
上述预设时间间隔为:基于第一预设数量以及区块生成时长计算得到的时间间隔。具体的,可以计算第一预设数量与区块生成时长之积,将计算得到的值确定为预设时间间隔。例如:假设第一预设数量为10,区块生成时长为50s,可以计算得到预设时间间隔为10*50=500s。
具体的,可以与上一确定目标节点的时刻间隔预设时间间隔的时刻,重新根据各节点当前对应的次数以及时长,从区块链系统包含的各节点中选择第一预设数量个目标节点。
由于各节点曾被选中为矿工节点的次数以及时长是不断变化的,也就是目标节点是不断变化的,所以,为了适应区块链系统的实时变化情况下,可以定期重新确定目标节点。
在本方案中,是从目标节点包含的备选节点中选择矿工节点,目标节点是区块链系统包含的各节点中第一预设数量个节点,由目标节点确认矿工节点,实现了部分去中心化。并且,目标节点是通过各节点曾被选中为矿工节点的次数以及时长确定的,也就是通过计算区块链系统中各节点的股权。另外,第一预设数量是根据区块链系统中发生故障的故障节点的数量统计值确定的,也就是所确定的第一预设数量个的目标节点考虑了区块链系统发生故障的情况,具有一定的容错机制。这种具有授权机制、容错机制的算法可以称为授权分布式故障容错算法(DPCFT)。
在上述步骤S101中,可以将目标节点称为投票被授予者(Block Producer),将备选节点称为提议者(Proposer),将区块链系统包含的各节点中除目标节点之外的节点称为告知者(Watcher)。
其中,投票被授予者组成的集群称为委员会。告知者仅被告知投票的结果,不参与投票过程。
各节点的关系如图2所示,其中,颜色较深的圆形框为提议者(Proposer),颜色较深的圆形框为投票被授予者(Block Producer),颜色最浅的圆形框为告知者(Watcher)。
参见图3a、图3b,图3a为应用本实施例提供的矿工确定方法的仿真图,图3b为比较本实施例提供的矿工确定方法与其他方法的对比图。
在图3a、图3b中,横坐标为测试时长,纵坐标为累计交易数,即生成区块的总数量。
结合图3a、图3b可以看到,随着测试时长的增大,DPCFT的交易量也随之增多,每秒交易量均高于市面上其他算法的每秒交易量。
与上述矿工节点确定方法相对应,本发明实施例还提供了一种矿工节点确定装置。
参见图4,图4为本发明实施例提供的一种矿工节点确定装置的结构示意图,上述装置包括以下模块401-402。
备选节点确定模块401,用于根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,从区块链系统包含的各节点中选择第一预设数量个目标节点,并将接收到用户触发的矿工竞选指示的目标节点确定为备选节点,其中,所述第一预设数量为:基于预设的故障节点数量计算得到的数量,所述预设的故障节点数量为:所述区块链系统中发生故障的故障节点的数量统计值;
矿工节点确定模块402,用于在所述备选节点向各目标节点发送矿工竞选请求后,根据各备选节点所接收的确认响应的数量,从各备选节点中确定矿工节点,其中,所述确认响应为:目标节点针对所述矿工竞选请求生成的响应。
由以上可见,应用本实施例提供的方案确定矿工节点时,从区块链系统包含的各节点中选择第一预设数量个目标节点,也就是目标节点的数量小于区块链系统包含的节点数量,从数量较少的目标节点中选择矿工节点,能够提高矿工节点确定的效率。
并且,由于是根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长选择目标节点,且各节点曾被选中为矿工节点的次数以及时长能够反映该节点具备成为矿工节点的所需性能程度,因此,基于各节点对应的次数以及时长能够准确选择目标节点,进而能够提高提高矿工节点确定的准确度。
另外,上述第一预设数量是基于区块链系统中发生故障的故障节点的数量统计值所确定的,上述统计值故障节点数量用于表征区块链系统正常运行时能够容纳的故障节点的数量,也就是上述的第一预设数量与区块链系统正常运行时能够容纳的故障节点的数量相关联,在从选择的第一预设数量个目标节点中选择备选节点时,即使区块链系统中出现故障节点,依然能够确定矿工节点,进一步提高了确定矿工节点的效率以及容错率。
本发明的一个实施例中,上述备选节点确定模块,包括:
目标节点确定子模块,用于根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,计算各节点的权重,将第一预设数量个权重最高的节点确定为目标节点;
备选节点确定子模块,用于将接收到用户触发的矿工竞选指示的目标节点确定为备选节点。
本发明的一个实施例中,上述目标节点确定子模块,具体用于按照以下表达式计算节点的权重Stock:
Stock=coinTime*Alpha+coinNum*Beta
其中,coinTime表示节点曾被选中为矿工节点的时长,coinNum表示节点曾被选中为矿工节点的次数,Alpha为第一预设系数,Beta为第二预设系数。
本发明的一个实施例中,上述第一预设数量为按照以下表达式计算得到的数量N:
N=af+b
其中,f表示所述预设的故障节点数量,a表示第三预设系数,a>2,且a为整数,b表示预设常数。
本发明的一个实施例中,上述装置还包括:
数量统计模块,用于统计各备选节点所接收的确认响应的数量之和;
信息生成模块,用于若统计得到的和值小于或者等于第二预设数量,生成表征所述区块链系统异常的告警信息,并将所述告警信息添加至所述矿工节点生成的区块中,其中,所述第二预设数量为:所述第一预设数量与所述预设的故障节点数量之差。
本发明的一个实施例中,上述备选节点确定模块,具体用于按照预设时间间隔,根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,从区块链系统包含的各节点中选择第一预设数量个目标节点,其中,所述预设时间间隔为:基于所述第一预设数量以及区块生成时长计算得到的时间间隔。
与上述矿工节点确定方法相对应,本发明实施例还提供了一种网络设备。
参见图5,图5为本发明实施例提供的一种网络设备的结构示意图,包括处理器501、通信接口502、存储器503和通信总线504,其中,处理器501,通信接口502,存储器503通过通信总线504完成相互间的通信,
存储器503,用于存放计算机程序;
处理器501,用于执行存储器503上所存放的程序时,实现本发明实施例提供的矿工节点确定方法。
上述电子设备提到的通信总线可以是外设部件互连标准(Peripheral ComponentInterconnect,PCI)总线或扩展工业标准结构(Extended Industry StandardArchitecture,EISA)总线等。该通信总线可以分为地址总线、数据总线、控制总线等。为便于表示,图中仅用一条粗线表示,但并不表示仅有一根总线或一种类型的总线。
通信接口用于上述电子设备与其他设备之间的通信。
存储器可以包括随机存取存储器(Random Access Memory,RAM),也可以包括非易失性存储器(Non-Volatile Memory,NVM),例如至少一个磁盘存储器。可选的,存储器还可以是至少一个位于远离前述处理器的存储装置。
上述的处理器可以是通用处理器,包括中央处理器(Central Processing Unit,CPU)、网络处理器(Network Processor,NP)等;还可以是数字信号处理器(Digital SignalProcessor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现场可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。
在本发明提供的又一实施例中,还提供了一种计算机可读存储介质,该计算机可读存储介质内存储有计算机程序,所述计算机程序被处理器执行时实现本发明实施例提供的矿工节点确定方法。
在本发明提供的又一实施例中,还提供了一种包含指令的计算机程序产品,当其在计算机上运行时,使得计算机执行时实现本发明实施例提供的矿工节点确定方法。
由以上可见,应用本实施例提供的方案确定矿工节点时,从区块链系统包含的各节点中选择第一预设数量个目标节点,也就是目标节点的数量小于区块链系统包含的节点数量,从数量较少的目标节点中选择矿工节点,能够提高矿工节点确定的效率。
并且,由于是根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长选择目标节点,且各节点曾被选中为矿工节点的次数以及时长能够反映该节点具备成为矿工节点的所需性能程度,因此,基于各节点对应的次数以及时长能够准确选择目标节点,进而能够提高提高矿工节点确定的准确度。
另外,上述第一预设数量是基于区块链系统中发生故障的故障节点的数量统计值所确定的,上述统计值故障节点数量用于表征区块链系统正常运行时能够容纳的故障节点的数量,也就是上述的第一预设数量与区块链系统正常运行时能够容纳的故障节点的数量相关联,在从选择的第一预设数量个目标节点中选择备选节点时,即使区块链系统中出现故障节点,依然能够确定矿工节点,进一步提高了确定矿工节点的效率以及容错率。
在上述实施例中,可以全部或部分地通过软件、硬件、固件或者其任意组合来实现。当使用软件实现时,可以全部或部分地以计算机程序产品的形式实现。所述计算机程序产品包括一个或多个计算机指令。在计算机上加载和执行所述计算机程序指令时,全部或部分地产生按照本发明实施例所述的流程或功能。所述计算机可以是通用计算机、专用计算机、计算机网络、或者其他可编程装置。所述计算机指令可以存储在计算机可读存储介质中,或者从一个计算机可读存储介质向另一个计算机可读存储介质传输,例如,所述计算机指令可以从一个网站站点、计算机、服务器或数据中心通过有线(例如同轴电缆、光纤、数字用户线(DSL))或无线(例如红外、无线、微波等)方式向另一个网站站点、计算机、服务器或数据中心进行传输。所述计算机可读存储介质可以是计算机能够存取的任何可用介质或者是包含一个或多个可用介质集成的服务器、数据中心等数据存储设备。所述可用介质可以是磁性介质,(例如,软盘、硬盘、磁带)、光介质(例如,DVD)、或者半导体介质(例如固态硬盘Solid State Disk(SSD))等。
需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
本说明书中的各个实施例均采用相关的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于装置、网络设备、计算机可读存储介质实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
以上所述仅为本发明的较佳实施例而已,并非用于限定本发明的保护范围。凡在本发明的精神和原则之内所作的任何修改、等同替换、改进等,均包含在本发明的保护范围内。
Claims (10)
1.一种矿工节点确定方法,其特征在于,所述方法包括:
根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,从区块链系统包含的各节点中选择第一预设数量个目标节点,并将接收到用户触发的矿工竞选指示的目标节点确定为备选节点,其中,所述第一预设数量为:基于预设的故障节点数量计算得到的数量,所述预设的故障节点数量为:所述区块链系统中发生故障的故障节点的数量统计值;
在所述备选节点向各目标节点发送矿工竞选请求后,根据各备选节点所接收的确认响应的数量,从各备选节点中确定矿工节点,其中,所述确认响应为:目标节点针对所述矿工竞选请求生成的响应。
2.根据权利要求1所述的方法,其特征在于,所述根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,从区块链系统包含的各节点中选择第一预设数量个目标节点,包括:
根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,计算各节点的权重,将第一预设数量个权重最高的节点确定为目标节点。
3.根据权利要求2所述的方法,其特征在于,所述根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,计算各节点的权重,包括:
按照以下表达式计算节点的权重Stock:
Stock=coinTime*Alpha+coinNum*Beta
其中,coinTime表示节点曾被选中为矿工节点的时长,coinNum表示节点曾被选中为矿工节点的次数,Alpha为第一预设系数,Beta为第二预设系数。
4.根据权利要求1-3中任一项所述的方法,其特征在于,所述第一预设数量为按照以下表达式计算得到的数量N:
N=af+b
其中,f表示所述预设的故障节点数量,a表示第三预设系数,a>2,且a为整数,b表示预设常数。
5.根据权利要求1-3中任一项所述的方法,其特征在于,所述方法还包括:
统计各备选节点所接收的确认响应的数量之和;
若统计得到的和值小于或者等于第二预设数量,生成表征所述区块链系统异常的告警信息,并将所述告警信息添加至所述矿工节点生成的区块中,其中,所述第二预设数量为:所述第一预设数量与所述预设的故障节点数量之差。
6.根据权利要求1-3中任一项所述的方法,其特征在于,所述根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,从区块链系统包含的各节点中选择第一预设数量个目标节点,包括:
按照预设时间间隔,根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,从区块链系统包含的各节点中选择第一预设数量个目标节点,其中,所述预设时间间隔为:基于所述第一预设数量以及区块生成时长计算得到的时间间隔。
7.一种矿工节点确定装置,其特征在于,所述装置包括:
备选节点确定模块,用于根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,从区块链系统包含的各节点中选择第一预设数量个目标节点,并将接收到用户触发的矿工竞选指示的目标节点确定为备选节点,其中,所述第一预设数量为:基于预设的故障节点数量计算得到的数量,所述预设的故障节点数量为:所述区块链系统中发生故障的故障节点的数量统计值;
矿工节点确定模块,用于在所述备选节点向各目标节点发送矿工竞选请求后,根据各备选节点所接收的确认响应的数量,从各备选节点中确定矿工节点,其中,所述确认响应为:目标节点针对所述矿工竞选请求生成的响应。
8.根据权利要求7所述的装置,其特征在于,所述备选节点确定模块,包括:
目标节点确定子模块,用于根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,计算各节点的权重,将第一预设数量个权重最高的节点确定为目标节点;
备选节点确定子模块,用于将接收到用户触发的矿工竞选指示的目标节点确定为备选节点。
9.根据权利要7或8所述的装置,其特征在于,所述装置还包括:
数量统计模块,用于统计各备选节点所接收的确认响应的数量之和;
信息生成模块,用于若统计得到的和值小于或者等于第二预设数量,生成表征所述区块链系统异常的告警信息,并将所述告警信息添加至所述矿工节点生成的区块中,其中,所述第二预设数量为:所述第一预设数量与所述预设的故障节点数量之差。
10.根据权利要求7或8所述的装置,其特征在于,所述备选节点确定模块,具体用于按照预设时间间隔,根据区块链系统包含的各节点曾被选中为矿工节点的次数以及时长,从区块链系统包含的各节点中选择第一预设数量个目标节点,其中,所述预设时间间隔为:基于所述第一预设数量以及区块生成时长计算得到的时间间隔。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110631397.4A CN113282463A (zh) | 2021-06-07 | 2021-06-07 | 一种矿工节点确定方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110631397.4A CN113282463A (zh) | 2021-06-07 | 2021-06-07 | 一种矿工节点确定方法及装置 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN113282463A true CN113282463A (zh) | 2021-08-20 |
Family
ID=77283641
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110631397.4A Pending CN113282463A (zh) | 2021-06-07 | 2021-06-07 | 一种矿工节点确定方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN113282463A (zh) |
-
2021
- 2021-06-07 CN CN202110631397.4A patent/CN113282463A/zh active Pending
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN108595157B (zh) | 区块链数据的处理方法、装置、设备和存储介质 | |
CN110471821B (zh) | 异常变更检测方法、服务器及计算机可读存储介质 | |
CN112162878A (zh) | 数据库故障发现方法、装置、电子设备及存储介质 | |
Finkelstein et al. | ‘Time‐free’preventive maintenance of systems with structures described by signatures | |
CN110023967B (zh) | 故障风险指标估计装置和故障风险指标估计方法 | |
Hou et al. | Optimal release times for software systems with scheduled delivery time based on the HGDM | |
CN109992473B (zh) | 应用系统的监控方法、装置、设备及存储介质 | |
CN111752850B (zh) | 区块链系统的测试方法及相关设备 | |
CN107992410B (zh) | 软件质量监测方法、装置、计算机设备和存储介质 | |
CN113590429A (zh) | 一种服务器故障诊断方法、装置及电子设备 | |
CN110633893A (zh) | 一种策略效能监控方法、装置以及计算机设备 | |
CN111708650A (zh) | 一种业务应用系统高可用性分析方法及系统 | |
CN112804333B (zh) | 出块节点的异常处理方法、装置、设备和存储介质 | |
WO2015095631A1 (en) | Communications security | |
WO2015171860A1 (en) | Automatic alert generation | |
CN114416490A (zh) | 基于区块链的监控报警方法、装置、电子设备及存储介质 | |
CN114444074A (zh) | 一种异常区块链节点检测方法及装置 | |
CN115879748A (zh) | 一种基于大数据的企业信息化管理集成平台 | |
CN113282463A (zh) | 一种矿工节点确定方法及装置 | |
Ulansky et al. | Availability Modeling of a Digital Electronic System with Intermittent Failures and Continuous Testing. | |
Zhou et al. | Stein–Chen approximation and error bounds for order fill rates in assemble‐to‐order systems | |
CN107896232B (zh) | 一种ip地址评估方法及装置 | |
CN113946515B (zh) | 代码覆盖率测试方法、装置、计算机设备及存储介质 | |
Rees et al. | Managing the uncertainties of software testing: a Bayesian approach | |
CN115314289A (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 | ||
RJ01 | Rejection of invention patent application after publication | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20210820 |