[发明专利]提高PBFT共识可扩展性的方法、装置、计算设备及存储介质在审
申请号: | 202110950596.1 | 申请日: | 2021-08-18 |
公开(公告)号: | CN113746635A | 公开(公告)日: | 2021-12-03 |
发明(设计)人: | 魏希三;谷琼;陈虎;宁彬;胡春阳;王毅;张一博 | 申请(专利权)人: | 湖北文理学院 |
主分类号: | H04L9/32 | 分类号: | H04L9/32;H04L9/08;G06Q40/04 |
代理公司: | 南京纵横知识产权代理有限公司 32224 | 代理人: | 徐瑛 |
地址: | 441021 湖*** | 国省代码: | 湖北;42 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 提高 pbft 共识 扩展性 方法 装置 计算 设备 存储 介质 | ||
1.提高PBFT共识可扩展性的方法,其特征在于,引入共识协调器,所述方法包括:
选择一个主节点来执行基于PBFT的一致性算法,所述主节点与共识协调器通信;
所述共识协调器从每个节点的交易池收集交易,根据收集交易的相等性对交易进行分类,并决定是否执行一致性算法;其中,
当所有交易都相等时,所述共识协调器请求主节点执行块生成;
当某些交易不相等时,所述共识协调器将交易分为普通交易和故障交易,并请求主节点仅对故障交易执行基于PBFT的一致性算法,生成约定交易;主节点将共识后的交易通知给共识协调器;共识协调器按时间顺序对所有普通交易和约定交易进行打包,并请求所有节点对打包的交易执行块生成。
2.根据权利要求1所述提高PBFT共识可扩展性的方法,其特征在于,在所有参与节点中,通过可验证随机函数VRF的方式选择一个主节点;当VRF随机数小于等于之前某个节点Nodei的情况下,这个编号i节点Nodei被选为主节点,以节点签名私钥sk为输入对节点号Nodei和种子seed签名后,生成VRF公钥并通知共识协调器。
3.根据权利要求1所述提高PBFT共识可扩展性的方法,其特征在于,所述共识协调器一旦得到主节点的选择主节点通知,则从每个节点的交易池中收集所有交易。
4.根据权利要求3所述提高PBFT共识可扩展性的方法,其特征在于,所述共识协调器通过使用公布的种子seed和Nodei生成一个随机数random来检查选定的主节点的有效性;如果生成的随机数等于从主节点接收到的Nodei,则共识协调器请求所有节点发送前一个时间timep到当前时间timec之间每个节点交易池中累积的所有交易;如果生成的随机数不等于从主节点接收到的Nodei,则共识协调器终止本轮所有协调步骤,等待下一个空闲状态。
5.提高PBFT共识可扩展性的装置,其特征在于,包括:
选择模块,用于从所有区块链节点中选择一个主节点来执行基于BFT的一致性算法,所述主节点与共识协调器通信;
所述共识协调器,用于从每个节点的交易池收集交易,根据收集交易的相等性对交易进行分类,并决定是否执行一致性算法;其中,
当所有交易都相等时,所述共识协调器请求主节点执行块生成;
当某些交易不相等时,所述共识协调器将交易分为普通交易和故障交易,并请求主节点仅对故障交易执行基于PBFT的一致性算法,生成约定交易;主节点将共识后的交易通知给共识协调器;共识协调器按时间顺序对所有普通交易和约定交易进行打包,并请求所有节点对打包的交易执行块生成。
6.根据权利要求5所述提高PBFT共识可扩展性的装置,其特征在于,所述选择模块,还用于在所有参与节点中,通过可验证随机函数VRF的方式选择一个主节点;当VRF随机数小于等于之前某个节点Nodei的情况下,这个编号i节点Nodei被选为主节点,以节点签名私钥sk为输入对节点号Nodei和种子seed签名后,生成VRF公钥并通知共识协调器。
7.根据权利要求5所述提高PBFT共识可扩展性的装置,其特征在于,所述共识协调器进一步用于,按时间顺序对所有公共交易和约定交易进行排序,并请求主节点生成包含所有已处理交易的新块。
8.一种计算设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现权利要求1至4任一项所述方法。
9.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质存储有执行权利要求1至4任一项所述方法的计算机程序。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于湖北文理学院,未经湖北文理学院许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202110950596.1/1.html,转载请声明来源钻瓜专利网。