[发明专利]可切换共识算法的区块链数据交互方法及装置在审
申请号: | 201910669873.4 | 申请日: | 2019-07-24 |
公开(公告)号: | CN110365695A | 公开(公告)日: | 2019-10-22 |
发明(设计)人: | 赖春晖;苏恒;彭顺求;万涛 | 申请(专利权)人: | 中国工商银行股份有限公司 |
主分类号: | H04L29/06 | 分类号: | H04L29/06;H04L29/08 |
代理公司: | 北京三友知识产权代理有限公司 11127 | 代理人: | 王涛;任默闻 |
地址: | 100140 北*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 算法 区块 数据交互 可插拔 可切换 链系统 处理逻辑 功能开发 通讯成本 业务场景 扩展性 耦合 大数据 复杂度 响应 解耦 可控 可用 研发 运维 内存 服务器 验证 智能 便利 监控 通讯 | ||
本发明提供一种可切换共识算法的区块链数据交互方法及装置,针对不同的业务场景接入不同的共识算法,实现可插拔接入,提升区块链系统共识效率,缩短数据交互响应时间,为区块链处理逻辑复杂的大数据业务在功能及性能上提供有力支持,在功能开发上提供便利,提高研发效率。该方法解决共识算法与区块链系统验证节点高耦合,提出可插拔共识算法的设计思路,实现了系统共识和智能合约解耦、共识算法高可用、易扩展性、共识节点的监控运维也更加方便、可控。同时解决了私有链环境下原有PBFT算法通讯成本过高的问题,改用RAFT算法后,通讯复杂度的降低。能有效降低区块链的平均响应时间、降低服务器的CPU和内存的利用率,节省了资源的开销。
技术领域
本发明涉及数据交互技术领域,更具体的,涉及一种可切换共识算法的区块链数据交互方法及装置。
背景技术
区块链技术作为随比特币而诞生的一项创新技术架构,它本质是公开透明、不可篡改、可追溯的分布式账本技术。区块链技术中,共识机制是其中核心的一个组成部分,区块链共识机制描述了分布式系统中多个节点之间,彼此对某个状态达成一致结果的过程,其目标是使所有的诚实节点用于访问容器的方法和装置保存一致的区块链视图,然而目前业界的区块链产品仅支持深度内嵌的单一的共识算法,如Hyperledger Fabric仅支持PBFT算法,以太坊仅支持POW的单一的共识算法,难以适用多变的业务场景,成为制约技术应用和业务推广的瓶颈。
发明内容
为了解决上述问题的至少一个,本申请一个方面实施例提供一种可切换共识算法的区块链数据交互方法,包括:
根据验证通过的数据交互请求,按照预设规则在预存储的多个共识算法中选定一个共识算法;
根据选定的共识算法,与同一区块链中的其他节点一同对所述数据交互请求执行共识操作,若未达成共识,重新执行共识操作,直至达成共识,输出共识结果;
根据所述共识结果和数据交互请求,执行数据交互操作。
在某些实施例中,所述根据验证通过的数据交互请求,按照预设规则在预存储的多个共识算法中选定一个共识算法,包括:
根据数据交互请求中的应用号、区块链场景类型以及当前网络环境安全性,按照预设的对应关系选定一个共识算法,所述对应关系为所述应用号、区块链场景类型以及当前网络环境安全性级别与所述共识算法的种类的映射关系。
在某些实施例中,所述根据验证通过的数据交互请求,按照预设规则在预存储的多个共识算法中选定一个共识算法,包括:
根据数据交互请求中的应用号、区块链场景类型以及当前网络环境安全性,生成整体安全级别;
根据所述整体安全级别和整体安全级别与共识算法的对应关系,选择一共识算法。
在某些实施例中,对数据交互产生的数据流量进行监控,若当前数据流量超过设定阈值时,延迟数据交互的处理或者停止处理该数据交互。
在某些实施例中,还包括:
通过双向认证的加密协议对区块链中的各节点进行加密。
在某些实施例中,还包括:
识别数据交互请求的发起用户的身份,验证所述发起用户是否是在区块链中已注册的用户;
若验证通过,识别数据交互请求中请求交互的数据是否是该发起用户被允许交互的数据,若为被允许交互的数据,则允许数据交互。
在某些实施例中,还包括:
检查数据交互请求发起用户的访问权限,若检查通过,则执行接收所述数据交互请求。
本申请另一个方面实施例提供一种可切换共识算法的区块链数据交互装置,包括:
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于中国工商银行股份有限公司,未经中国工商银行股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201910669873.4/2.html,转载请声明来源钻瓜专利网。