CN108833484A - Pos机制下记账节点选择方法 - Google Patents
Pos机制下记账节点选择方法 Download PDFInfo
- Publication number
- CN108833484A CN108833484A CN201810492790.8A CN201810492790A CN108833484A CN 108833484 A CN108833484 A CN 108833484A CN 201810492790 A CN201810492790 A CN 201810492790A CN 108833484 A CN108833484 A CN 108833484A
- Authority
- CN
- China
- Prior art keywords
- nodes
- level
- accounting nodes
- candidate nodes
- candidate
- 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
Classifications
-
- 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
-
- 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
- G06Q40/00—Finance; Insurance; Tax strategies; Processing of corporate or income taxes
- G06Q40/04—Trading; Exchange, e.g. stocks, commodities, derivatives or currency exchange
-
- 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/1001—Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
-
- 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/1001—Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
- H04L67/1004—Server selection for load balancing
-
- 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/1001—Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
- H04L67/1004—Server selection for load balancing
- H04L67/1008—Server selection for load balancing based on parameters of servers, e.g. available memory or workload
Abstract
本发明特别涉及一种POS机制下记账节点选择方法,包括以下步骤:记账节点接受网络中的交易信息,并将交易信息写入区块;记账节点每隔一段时间或区块个数在区块链网络中发起新的记账节点选举,普通节点收到邀请后判断自身是否符合参选条件;决定参选的普通节点向区块链系统提交参选保证金;记账节点从确认缴纳保证金的节点筛选出一级候选节点;从一级候选节点选择权益最大者为当选记账节点后结束。该方法可以避免中心化问题,降低了权益对中小节点的影响,提高恶意节点攻击的成本,维护了权益本身的价值,刺激参与节点更多保存权益,以提高入选记账节点的概率。
Description
技术领域
本发明涉及区块链技术领域,特别涉及一种POS机制下记账节点选择方法。
背景技术
区块链(BlockChain)技术作为一种分布式账本技术,具有去中心化、分布式共识、匿名和可追溯特性,被认为是最有前途的技术之一。作为分布式网络的一种应用,如何在分布式网络中达成共识,选择记账节点,是区块链必须要解决的问题之一。目前主流的共识机制主要有工作量证明(Proof of Work,简称POW)和权益证明(Proof of Stake,简称POS)两种。POW和POS分别采用了计算力和权益持有的比率两种方法来选择记账节点。
POS机制以权益作为基础,除权益利息奖励以外,其最大的奖励来自记账节点的记账奖励。但是,其记账节点的选择跟节点持有的权益有正相关,即一个节点拥有的权益越多,被选择为记账节点的几率就越大,因而获得记账奖励的机会就越多。该机制的缺点非常明显,长期运行中,权益多的节点获得的奖励越多,造成大者恒大,后续进入的节点因为权益占比低的原因,无法获得更多奖励,没有参与积极性,容易退出网络,造成网络收缩和崩塌。同时,因为奖励导致的权益集中,权益大的节点也会更多被选为记账节点,导致更多的主导权,引起中心化的问题。
发明内容
本发明的目的在于提供一种POS机制下记账节点选择方法,提高选择的随机性,增加中小权益节点获得记账权的概率。
为实现以上目的,本发明采用的技术方案为:一种POS机制下记账节点选择方法,包括以下步骤:(A)记账节点接受网络中的交易信息,并将交易信息写入区块;(B)记账节点判断是否经过设定时间T或者写入区块的数量达到设定值m,如果是,则执行下一步,否则返回步骤A;(C)记账节点在区块链网络中发起新的记账节点选举,每个普通节点收到记账节点的选举邀请后判断自身是否符合参选条件,参选条件为自身当选为记账节点的频率是否超过设定阈值,如果超过则自动失去候选资格,否则可以参选;(D)决定参选的普通节点向区块链系统提交参选保证金;(E)记账节点确认缴纳保证金的节点为候选节点,并从候选节点中根据保证金大小筛选出一级候选节点;(F)对于一级候选节点,按权益大小排序,选择权益最大者为当选记账节点后结束。
与现有技术相比,本发明存在以下技术效果:通过对当选为记账节点的频率的要求,加上时间和出块限制,确保不会有节点一直当选记账节点,造成中心化问题;同时,通过保证金排序机制,使得中小权益节点可以通过提高保证金的方式来提高入选记账节点的概率,降低了权益对中小节点的影响,还能提高恶意节点攻击的成本;最后通过权益排序机制,维护了权益本身的价值,刺激参与节点更多保存权益,以提高入选记账节点的概率。
附图说明
图1是本发明的流程图。
具体实施方式
下面结合图1,对本发明做进一步详细叙述。
参阅图1,一种POS机制下记账节点选择方法,包括以下步骤:(A)记账节点接受网络中的交易信息,并将交易信息写入区块;(B)记账节点判断是否经过设定时间T或者写入区块的数量达到设定值m,如果是,则执行下一步,否则返回步骤A;(C)记账节点在区块链网络中发起新的记账节点选举,每个普通节点收到记账节点的选举邀请后判断自身是否符合参选条件,参选条件为自身当选为记账节点的频率是否超过设定阈值,如果超过则自动失去候选资格,否则可以参选。这里通过对当选为记账节点的频率的要求,加上时间和出块限制,确保不会有节点一直当选记账节点,造成中心化问题。(D)决定参选的普通节点向区块链系统提交参选保证金;(E)记账节点确认缴纳保证金的节点为候选节点,并从候选节点中根据保证金大小筛选出一级候选节点。这里通过保证金排序机制,使得中小权益节点可以通过提高保证金的方式来提高入选记账节点的概率,降低了权益对中小节点的影响,还能提高恶意节点攻击的成本。(F)对于一级候选节点,按权益大小排序,选择权益最大者为当选记账节点后结束。通过权益排序机制,维护了权益本身的价值,刺激参与节点更多保存权益,以提高入选记账节点的概率。
步骤B中的时间T和设定值m可以按照要求进行设定,本实施例中,设定时间T为5~20分钟,设定值m为10~30个块,优选地,设定时间为10分钟,设定值m为20个块。这样,步骤B就变为:记账节点判断是否经过10分钟或者写入20个块,如果是,则执行下一步,否则返回步骤A。
通过保证金的大小从候选节点中筛选出一级候选节点,不具有随机性,保证金缴纳的越多且权益越大的候选节点入选记账节点的概率更大。为了进一步提高中小权益节点入选概率,本发明中优选地:所述的步骤E中,按如下步骤从候选节点中筛选出一级候选节点:(E1)记账节点从候选节点中随机选出指定个数的候选节点作为二级候选节点;(E2)对于二级候选节点,按保证金从大到小排序,并根据保证金大小选择指定个数的一级候选节点。步骤E1让所有缴纳保证金的候选节点进行第一轮随机筛选,降低保证金最大的那个节点参选的概率,从而使得中小权益节点得到保障。
步骤E1中的随机选择,有很多方案可以实现,本发明中优选地:所述的步骤E1中,按如下步骤从候选节点中筛选出二级候选节点:(E11)记账节点对候选节点按收到保证金共识的时间进行排序,每个候选节点分配一个从1开始的ID号,ID号根据收到的顺序按自然计数增长;(E12)在候选节点中,按素数表中的序号,选择ID号为素数的候选节点为二级候选节点;选择时,若候选节点数小于等于500个,则按素数表,选取全部素数ID号的节点为二级候选节点;若候选节点数大于500个,则随机决定从候选列表的开头ID号或者结尾ID号作为起始序号,向后或者向前寻找ID号为素数的节点,取96个ID号为素数的节点为二级候选节点。程序中很多随机的方法是伪随机,存在一定的规律性,这里通过步骤E11和步骤E12,根据候选节点缴纳保证金的时间来生成ID号,再对ID号进行素数选取,这样的过程随机性非常强,基本无规律可循,对所有的候选节点来说更为公平。候选节点可以有很多,二级候选节点个数应当做一个限制,本实施例中,将二级候选节点的个数控制在96个以内。
同样地,一级候选节点的个数也应当做个限制,不能选择过多。本实施例中,所述的步骤E2中,如果二级候选节点大于50个,则选择保证金最大的前50个二级候选节点作为一级候选节点;如果二级候选节点小于等于50个,则选择全部的二级候选节点作为一级候选节点,这样就能保证一级候选节点的个数不会超过50个。
自身当选为记账节点的频率阈值可以设定为一定时间内当选过记账节点或连续若干次当选为记账节点,加上这个频率限制,可以避免某个节点被经常选为记账节点。本发明中具体地,所述的步骤C中,自身当选为记账节点的频率阈值为连续两次当选为记账节点,也即:之前连续两次当选为记账节点的那个普通节点不再参与本次选举,这样,同一个节点最多会被连续两次选为记账节点,不会超过三次。
优选地,所述的步骤C中,参选条件还包括普通节点持有权益的时间必须超过设定的时间,同时满足两个参选条件的普通节点才能参与本次选举。增加持有权益时间作为要求,保证参与节点都是系统中的长期节点,防止大量临时恶意节点加入导致的恶意节点当选概率过高的问题,避免利用大量临时节点攻击选举机制的情况出现。
本发明中提出的这种基于保证金加权益,结合素数表形成随机方法的多重排序的记账节点选择算法,在参考权益比重的基础上,引入保证金机制,加上素数表提高选择的随机性,增加中小权益节点获得记账权的概率,解决现有的POS算法按权益选择记账节点而导致的中小节点当选记账节点几率过低的问题,避免引发的退出网络问题和长期运行中可能出现的中心化问题,同时还能保证POS本身的激励特性。
Claims (7)
1.一种POS机制下记账节点选择方法,其特征在于:包括以下步骤:
(A)记账节点接受网络中的交易信息,并将交易信息写入区块;
(B)记账节点判断是否经过设定时间T或者写入区块的数量达到设定值m,如果是,则执行下一步,否则返回步骤A;
(C)记账节点在区块链网络中发起新的记账节点选举,每个普通节点收到记账节点的选举邀请后判断自身是否符合参选条件,参选条件为自身当选为记账节点的频率是否超过设定阈值,如果超过则自动失去候选资格,否则可以参选;
(D)决定参选的普通节点向区块链系统提交参选保证金;
(E)记账节点确认缴纳保证金的节点为候选节点,并从候选节点中根据保证金大小筛选出一级候选节点;
(F)对于一级候选节点,按权益大小排序,选择权益最大者为当选记账节点后结束。
2.如权利要求1所述的POS机制下记账节点选择方法,其特征在于:所述的步骤E中,按如下步骤从候选节点中筛选出一级候选节点:
(E1)记账节点从候选节点中随机选出指定个数的候选节点作为二级候选节点;
(E2)对于二级候选节点,按保证金从大到小排序,并根据保证金大小选择指定个数的一级候选节点。
3.如权利要求2所述的POS机制下记账节点选择方法,其特征在于:所述的步骤E1中,按如下步骤从候选节点中筛选出二级候选节点:
(E11)记账节点对候选节点按收到保证金共识的时间进行排序,每个候选节点分配一个从1开始的ID号,ID号根据收到的顺序按自然计数增长;
(E12)在候选节点中,按素数表中的序号,选择ID号为素数的候选节点为二级候选节点;选择时,若候选节点数小于等于500个,则按素数表,选取全部素数ID号的节点为二级候选节点;若候选节点数大于500个,则随机决定从候选列表的开头ID号或者结尾ID号作为起始序号,向后或者向前寻找ID号为素数的节点,取96个ID号为素数的节点为二级候选节点。
4.如权利要求3所述的POS机制下记账节点选择方法,其特征在于:所述的步骤E2中,如果二级候选节点大于50个,则选择保证金最大的前50个二级候选节点作为一级候选节点;如果二级候选节点小于等于50个,则选择全部的二级候选节点作为一级候选节点。
5.如权利要求4所述的POS机制下记账节点选择方法,其特征在于:所述的步骤C中,自身当选为记账节点的频率阈值为连续两次当选为记账节点。
6.如权利要求5所述的POS机制下记账节点选择方法,其特征在于:所述的步骤C中,参选条件还包括普通节点持有权益的时间必须超过设定的时间,同时满足两个参选条件的普通节点才能参与本次选举。
7.如权利要求6所述的POS机制下记账节点选择方法,其特征在于:所述的步骤B中,设定时间T为5~20分钟,设定值m为10~30个块。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810492790.8A CN108833484B (zh) | 2018-05-22 | 2018-05-22 | Pos机制下记账节点选择方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810492790.8A CN108833484B (zh) | 2018-05-22 | 2018-05-22 | Pos机制下记账节点选择方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN108833484A true CN108833484A (zh) | 2018-11-16 |
CN108833484B CN108833484B (zh) | 2020-12-08 |
Family
ID=64148991
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201810492790.8A Active CN108833484B (zh) | 2018-05-22 | 2018-05-22 | Pos机制下记账节点选择方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN108833484B (zh) |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109639416A (zh) * | 2018-12-21 | 2019-04-16 | 深圳市网心科技有限公司 | 一种验证人节点确定方法、系统、装置及计算机存储介质 |
CN110348248A (zh) * | 2019-07-16 | 2019-10-18 | 山西智博睿星科技有限公司 | 一种区块链技术中分布式记账权生成方法 |
CN110610421A (zh) * | 2019-09-03 | 2019-12-24 | 北京航空航天大学 | 分片框架下的保证金管理方法及装置 |
CN111372220A (zh) * | 2020-02-28 | 2020-07-03 | 长安大学 | 一种应用于车联网的区块链共识方法 |
CN113900814A (zh) * | 2021-10-13 | 2022-01-07 | 中国人民解放军国防科技大学 | 一种实现链上记账区块频度动态调整的方法及系统 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106548349A (zh) * | 2016-11-02 | 2017-03-29 | 江苏通付盾科技有限公司 | 交易信息验证方法及系统 |
CN106850536A (zh) * | 2016-11-30 | 2017-06-13 | 北京瑞卓喜投科技发展有限公司 | 区块链共识方法及系统 |
US20170236120A1 (en) * | 2016-02-11 | 2017-08-17 | Oracle International Corporation | Accountability and Trust in Distributed Ledger Systems |
CN107493173A (zh) * | 2017-08-30 | 2017-12-19 | 北京知金链网络技术有限公司 | 区块链随机数共识推举方法 |
CN108009918A (zh) * | 2017-11-23 | 2018-05-08 | 深圳捷汇科技有限公司 | 区块链共识算法交易系统的记账方法及电子设备 |
-
2018
- 2018-05-22 CN CN201810492790.8A patent/CN108833484B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20170236120A1 (en) * | 2016-02-11 | 2017-08-17 | Oracle International Corporation | Accountability and Trust in Distributed Ledger Systems |
CN106548349A (zh) * | 2016-11-02 | 2017-03-29 | 江苏通付盾科技有限公司 | 交易信息验证方法及系统 |
CN106850536A (zh) * | 2016-11-30 | 2017-06-13 | 北京瑞卓喜投科技发展有限公司 | 区块链共识方法及系统 |
CN107493173A (zh) * | 2017-08-30 | 2017-12-19 | 北京知金链网络技术有限公司 | 区块链随机数共识推举方法 |
CN108009918A (zh) * | 2017-11-23 | 2018-05-08 | 深圳捷汇科技有限公司 | 区块链共识算法交易系统的记账方法及电子设备 |
Non-Patent Citations (1)
Title |
---|
刘肖飞: ""基于动态授权的拜占庭容错共识算法的区块链性能改进研究"", 《中国优秀硕士学位论文全文数据库 信息科技辑》 * |
Cited By (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109639416A (zh) * | 2018-12-21 | 2019-04-16 | 深圳市网心科技有限公司 | 一种验证人节点确定方法、系统、装置及计算机存储介质 |
CN110348248A (zh) * | 2019-07-16 | 2019-10-18 | 山西智博睿星科技有限公司 | 一种区块链技术中分布式记账权生成方法 |
CN110348248B (zh) * | 2019-07-16 | 2023-07-21 | 山西智博睿星科技有限公司 | 一种区块链技术中分布式记账权生成方法 |
CN110610421A (zh) * | 2019-09-03 | 2019-12-24 | 北京航空航天大学 | 分片框架下的保证金管理方法及装置 |
CN110610421B (zh) * | 2019-09-03 | 2022-03-25 | 北京航空航天大学 | 分片框架下的保证金管理方法及装置 |
CN111372220A (zh) * | 2020-02-28 | 2020-07-03 | 长安大学 | 一种应用于车联网的区块链共识方法 |
CN111372220B (zh) * | 2020-02-28 | 2024-03-05 | 广州大鱼创福科技有限公司 | 一种应用于车联网的区块链共识方法 |
CN113900814A (zh) * | 2021-10-13 | 2022-01-07 | 中国人民解放军国防科技大学 | 一种实现链上记账区块频度动态调整的方法及系统 |
CN113900814B (zh) * | 2021-10-13 | 2023-12-01 | 中国人民解放军国防科技大学 | 一种实现链上记账区块频度动态调整的方法及系统 |
Also Published As
Publication number | Publication date |
---|---|
CN108833484B (zh) | 2020-12-08 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN108833484A (zh) | Pos机制下记账节点选择方法 | |
CN107483986A (zh) | 一种赠送礼物的方法及系统 | |
CN103475717B (zh) | 一种基于社交网络的好友推荐方法和系统 | |
CN108985732A (zh) | 基于无区块的dag技术的共识和账本数据组织方法及系统 | |
CN110751468A (zh) | 用于区块链扩展的多向状态通道方法、系统及介质 | |
CN109035011A (zh) | 一种区块链dag宽度的控制方法与系统 | |
CN109639479A (zh) | 基于生成对抗网络的网络流量数据增强方法及装置 | |
CN110288377A (zh) | 广告投放优化方法及装置、存储介质及电子装置 | |
CN106845633A (zh) | 神经网络信息转换方法和系统 | |
CN106875006A (zh) | 人工神经元信息转换为脉冲神经元信息的方法和系统 | |
CN107545376A (zh) | 一种下发任务的方法、装置及系统 | |
CN111131184A (zh) | 一种区块链共识机制的自主调节方法 | |
CN111127120A (zh) | 基于区块链技术的服务数据处理系统、各相关节点及方法 | |
CN110460471A (zh) | 一种超级节点竞选方法、装置及存储介质 | |
CN105279688A (zh) | 订单数据处理方法及系统 | |
CN110141868A (zh) | 一种用于竞速类游戏应用的ai追逐方法 | |
TWI766167B (zh) | 收款控制方法、裝置、伺服器及可讀儲存媒體 | |
CN106445683A (zh) | 一种服务器资源分发方法及装置 | |
CN104715390A (zh) | 用于网络应用的数据处理方法和装置 | |
Li et al. | Towards describing multi-fractality of traffic using local Hurst function | |
Elliott | Nash equilibrium of multiple, non-uniform bitcoin block withholding attackers | |
CN109191318A (zh) | 一种有效贡献激励信息传播的目标寻找方法及装置 | |
CN104759092A (zh) | 一种互联网平台积分博弈结算的方法 | |
CN115564419A (zh) | 基于区块链实现跨行转账的方法及系统 | |
US20190005778A1 (en) | Method for operating competitive events |
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 |