[发明专利]基于纠错码的共享区块链数据存储的共识有效
| 申请号: | 201980005802.2 | 申请日: | 2019-11-06 |
| 公开(公告)号: | CN111406252B | 公开(公告)日: | 2022-04-15 |
| 发明(设计)人: | 陆钟豪;卓海振 | 申请(专利权)人: | 支付宝(杭州)信息技术有限公司 |
| 主分类号: | G06F11/10 | 分类号: | G06F11/10 |
| 代理公司: | 北京博思佳知识产权代理有限公司 11415 | 代理人: | 艾佳 |
| 地址: | 310000 浙江省杭州市*** | 国省代码: | 浙江;33 |
| 权利要求书: | 查看更多 | 说明书: | 查看更多 |
| 摘要: | |||
| 搜索关键词: | 基于 纠错码 共享 区块 数据 存储 共识 | ||
1.一种计算机实现的用于在可通信地耦接到区块链网络的计算设备上执行的可信执行环境TEE中处理区块链数据的方法,所述方法包括:
从所述区块链网络中的区块链节点检索多个区块;
使用纠错编码ECC对所述多个区块进行编码以生成多个编码区块,所述多个编码区块的编码率不大于所述区块链网络所需的最小诚实区块链节点数除以区块链节点的总数;
对于所述多个编码区块中的每个编码区块:
将所述编码区块划分为多个数据集,其中,所述多个数据集包括一个或多个信息位数据集和一个或多个冗余位数据集;
计算所述多个数据集的哈希值;
向所述区块链网络中的多个区块链节点分别发送请求,所述请求包括所述多个数据集中的至少一个数据集、所述哈希值以及提供关于所述多个数据集至所述多个区块链节点的分配的数据存储方案;
从至少一定数量的区块链节点接收表示接受所述请求的响应,所述一定数量等于所述一个或多个信息位数据集的数量;以及
向所述多个区块链节点分别发送采用所述数据存储方案的通知。
2.如权利要求1所述的方法,其中,采用所述数据存储方案还包括:
基于所述数据存储方案中提供的所述分配,存储所述多个数据集中的至少一个数据集;以及
删除与所述多个区块相关联的现有区块链数据。
3.如权利要求1或2所述的方法,其中,
所述多个数据集的数量等于所述区块链网络中的所述区块链节点的数量,并且
所述多个编码区块的编码率等于所述区块链网络所需的最小诚实区块链节点数除以区块链节点的总数。
4.如权利要求1或2所述的方法,其中,检索所述多个区块是响应于区块链节点从所述区块链网络退出执行的。
5.如权利要求4所述的方法,所述方法还包括:
对于所述区块链节点退出后的所述多个区块中的每个区块:
确定存储所述区块的ECC编码版本的至少一部分的区块链节点的第一数量和存储所述区块的ECC编码版本的冗余位的至少一部分的区块链节点的第二数量;
确定所述区块链网络中的区块链节点的总数和所述区块链网络可容忍的故障区块链节点的最大数量;以及
确定所述第一数量与所述第二数量之间的第一差是否小于或等于所述总数与所述最大数量之间的第二差。
6.如权利要求5所述的方法,其中,对所述多个区块进行编码是响应于确定所述第一差大于所述第二差执行的。
7.如权利要求1或2所述的方法,其中,当所述计算设备的计算资源的利用率小于或等于预定值时,执行所述ECC。
8.如权利要求1或2所述的方法,其中,所述ECC是通过向所述多个区块添加冗余位来执行的纠删编码。
9.如权利要求1或2所述的方法,其中,所述所需的最小诚实区块链节点数基于实用拜占庭容错PBFT共识协议确定。
10.一种用于通信共享的区块链数据的系统,包括:
一个或多个处理器;和
耦接到所述一个或多个处理器并且其上存储有指令的一个或多个计算机可读存储器,所述指令能由所述一个或多个处理器执行以执行权利要求1至9中任一项所述的方法。
11.一种用于通信共享的区块链数据的装置,所述装置包括用于执行权利要求1至9中的任一项所述的方法的多个模块。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于支付宝(杭州)信息技术有限公司,未经支付宝(杭州)信息技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201980005802.2/1.html,转载请声明来源钻瓜专利网。





