[发明专利]使用布隆过滤器对被许可的区块链进行去同步恢复的方法和系统有效

专利信息
申请号: 201780032307.1 申请日: 2017-04-19
公开(公告)号: CN109313654B 公开(公告)日: 2022-01-07
发明(设计)人: S·C·戴维斯 申请(专利权)人: 万事达卡国际股份有限公司
主分类号: G06F16/901 分类号: G06F16/901;G06Q40/04;H04L9/32
代理公司: 北京世峰知识产权代理有限公司 11713 代理人: 卓霖;张春媛
地址: 美国*** 国省代码: 暂无信息
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 使用 过滤器 许可 区块 进行 同步 恢复 方法 系统
【权利要求书】:

1.一种使用布隆过滤器恢复丢失数据或额外数据的方法,包括:

在处理服务器的交易数据库中存储多个交易消息,其中,每个交易消息包括与区块链交易相关的结构化数据集,所述结构化数据集至少包括交易值;

由所述处理服务器的生成模块生成所述多个交易消息的布隆过滤器,其中,所述布隆过滤器使用预定数量的散列循环生成并且所述布隆过滤器的尺寸是存储在所述交易数据库中的所述多个交易消息的数量的至少两倍;

由所述处理服务器的所述生成模块生成恢复消息,其中,所述恢复消息至少包括所述多个交易消息的数量、散列循环的预定数量、所述尺寸和生成的布隆过滤器;

由所述处理服务器的发送设备以电子方式将生成的恢复消息发送到至少一个共识节点;

由所述处理服务器的接收设备从所述至少一个共识节点中的一个节点或多个节点接收响应消息,其中,所述响应消息包括至少一个附加交易消息;以及

由所述处理服务器的查询模块在所述交易数据库上执行查询以插入所述至少一个附加交易消息。

2.根据权利要求1所述的方法,还包括:

由所述处理服务器的散列模块使用与包括在所述多个交易消息中的每个交易消息中的交易值相关联的交易参考值,来生成所述多个交易消息的Merkle根;

由所述处理服务器的所述接收设备从所述至少一个共识节点中的每一个共识节点接收提议消息,其中,所述提议消息至少包括提议的Merkle根;以及

在以电子方式发送生成的恢复消息之前,由所述处理服务器的验证模块验证所生成的Merkle根不等于在每个接收的提议消息中包括的提议的Merkle根。

3.根据权利要求2所述的方法,还包括:

由所述处理服务器的所述散列模块使用与包括在每个相应交易消息中的所述交易值相关联的交易参考值,来生成所述多个交易消息和所述至少一个附加交易消息的新的Merkle根;以及

由所述处理服务器的所述验证模块验证所述新的Merkle根等于在每个接收的提议消息中包括的所述提议的Merkle根。

4.根据权利要求2所述的方法,还包括:

由所述处理服务器的所述散列模块通过使用预定的散列算法对相应的交易值进行散列,来生成与包括在所述多个交易消息中的每个交易消息中的所述交易值相关联的交易参考值。

5.根据权利要求2所述的方法,还包括:

由所述处理服务器的所述查询模块在生成所述Merkle根之前,基于自然排序对与包括在所述多个交易消息中的每个交易消息中的所述交易值相关联的所述交易参考值进行排序。

6.根据权利要求1所述的方法,其中,

多个所述交易消息中的每一个交易消息还包括特定时隙标识符,

所述恢复消息和响应消息中的每一个还包括所述特定时隙标识符,以及

所述至少一个附加交易消息中的每一个附加交易消息包括所述特定时隙标识符。

7.根据权利要求1所述的方法,其中,对于所述预定数量的散列循环中的每一个,使用预定的散列算法生成所述布隆过滤器。

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于万事达卡国际股份有限公司,未经万事达卡国际股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/201780032307.1/1.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top