[发明专利]一种区块链中区块传播的方法及装置有效
申请号: | 201910880129.9 | 申请日: | 2019-09-18 |
公开(公告)号: | CN110474846B | 公开(公告)日: | 2022-04-08 |
发明(设计)人: | 熊璐;杨阳;陈舟;黄自力;范磊 | 申请(专利权)人: | 中国银联股份有限公司 |
主分类号: | H04L45/16 | 分类号: | H04L45/16;H04L45/24;H04L67/1074;H04L9/32 |
代理公司: | 北京同达信恒知识产权代理有限公司 11291 | 代理人: | 张怀阳 |
地址: | 200135 *** | 国省代码: | 上海;31 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 区块 传播 方法 装置 | ||
本发明公开了一种区块链中区块传播的方法及装置,该方法包括获取新生成的区块,将新生成的区块划分为区块头部和多个小块,小块包括生成者的签名,将区块头部和多个小块以不同的路径进行随机广播,以使其它区块链节点接收区块头部和多个小块并将区块头部和多个小块组装为新生成的区块。由于将区块切割为多个独立的小块,并且将每个小块随机选择相邻的区块链节点进行传播,从而保证了整个区块的不同部分在不同路径上传播,避免出现完整数据包按照固定路径传播所引起的网络等待。同时,小块通过不同的路径进行传播保证了所有节点间的网络均有数据传输,带宽的时间利用率高。
技术领域
本发明实施例涉及区块链技术领域,尤其涉及一种区块链中区块传播的方法及装置。
背景技术
区块链(blockchain)的基本组成单元是区块(block),区块由交易数据、前一区块的哈希值、矿工信息等数据构成,其中区块的主要字段为交易数据。在区块链系统中,每一个区块通过P2P网络广播传播到所有的共识节点,最终实现数据的共识。在高吞吐率应用中,用户每秒将产生大量的交易数据。交易数据的增加将会引起区块大小的增加。比特币等区块链系统通过限制区块的出块间隔以及单个区块的大小限定了区块链系统的吞吐率。
目前提高吞吐率方案主要有以下两种:一是直接增加区块大小或缩小出块时延。这种技术由于区块产生时间间隔应该大于区块在全网中传播的时延,并留有一定的安全间隔,因此不能无限缩小出块时延。同时,增加区块大小会进一步加重网络的传播时延,因此这种方法不能够提供比以太坊更高的吞吐率。二是采用分片技术。但是分片技术目前尚不够成熟,尤其跨链交易的数据一致性难以保证。并且分片后全网数据同步与查询也存在困难。
因此,目前提高吞吐率的方案都有一定的限制,无法应用在各种区块链系统中。
发明内容
本发明实施例提供一种区块链中区块传播的方法及装置,用以实现有效减少区块传播时延,提高区块链的吞吐率。
第一方面,本发明实施例提供一种区块链中区块传播的方法,包括:
获取新生成的区块;
将所述新生成的区块划分为区块头部和多个小块,所述小块包括生成者的签名;
将所述区块头部和所述多个小块以不同的路径进行随机广播,以使其它区块链节点接收所述区块头部和所述多个小块并将所述区块头部和所述多个小块组装为所述新生成的区块。
上述技术方案中,由于将区块切割为多个独立的小块,并且将每个小块随机选择相邻的区块链节点进行传播,从而保证了整个区块的不同部分在不同路径上传播,避免出现完整数据包按照固定路径传播所引起的网络等待。同时,小块通过不同的路径进行传播保证了所有节点间的网络均有数据传输,带宽的时间利用率高。
可选的,所述将所述区块头部和所述多个小块以不同的路径进行随机广播,包括:
将所述区块头部和所述多个小块中的每一个小块随机选择一个或者多个相邻的区块链节点进行广播。
上述技术方案中,由于要求每个小片传播选择相邻的区块链节点的随机性,从而保证了整个区块的不同部分在不同路径上传播。
可选的,所述将所述区块头部和所述多个小块中的每一个小块随机选择一个或者多个相邻的区块链节点进行广播,包括:
将所述区块头部优先于所述多个小块中的每一个小块随机选择一个或者多个相邻的区块链节点进行广播。
可选的,所述方法还包括:
接收第一区块链节点发送的第一小块,所述第一区块链节点为其它相邻的区块链节点中的任意一个;所述第一小块为所述第一区块链节点广播的或所述第一区块链节点转发的;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于中国银联股份有限公司,未经中国银联股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201910880129.9/2.html,转载请声明来源钻瓜专利网。
- 上一篇:流表项淘汰方法及相关装置
- 下一篇:信号放大路由器