[发明专利]一种交易路由方法、装置及计算机可读存储介质有效
申请号: | 202010351450.0 | 申请日: | 2020-04-28 |
公开(公告)号: | CN111553669B | 公开(公告)日: | 2021-09-10 |
发明(设计)人: | 李茂材;王宗友;张劲松;黄焕坤;周开班;时一防;刘区城;刘攀;蓝虎;杨常青;朱耿良;孔利 | 申请(专利权)人: | 腾讯科技(深圳)有限公司 |
主分类号: | G06Q20/02 | 分类号: | G06Q20/02 |
代理公司: | 广州三环专利商标代理有限公司 44202 | 代理人: | 熊永强;杜维 |
地址: | 518057 广东省深圳*** | 国省代码: | 广东;44 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 交易 路由 方法 装置 计算机 可读 存储 介质 | ||
本发明实施例提供了一种交易路由方法、装置及计算机可读存储介质,方法包括:共识节点在接收到交易数据时,确定交易数据对应的目标交易池,根据目标交易池的最短前缀从多个路由转发表中获取第二交易池的地址,该多个路由转发表包括多个子树中每个子树对应的路由转发表,该多个子树是以第一叶子节点为基准对字典树从根节点开始拆分得到的,第一叶子节点对应表示该共识节点的交易池,每个路由转发表用于记录对应子树中预设数量的叶子节点对应表示的交易池的地址,并向第二交易池的地址对应的共识节点发送交易数据,从而可以保证交易数据的转发过程不受单个节点上线或下线的影响,容错性强,使得交易能够被快速传递给对应的交易池。
技术领域
本发明涉及计算机技术领域,尤其涉及一种交易路由方法、装置及计算机可读存储介质。
背景技术
在目前的区块链网络中,节点的交易池向某个交易池发送交易的过程中,通常会经过多个节点的交易池的转发,但是如果有节点上线或者下线则很可能会影响交易的转发过程,例如第一节点的交易池向第二节点的交易池发送交易的时候需要第三节点的交易池和第四节点的交易池参与转发,即第一节点的交易池先向第三节点的交易池发送交易,第三节点的交易池再向第四节点的交易池转发交易,然后第四节点的交易池再向第二节点的交易池转发交易,但是如果第四节点下线,则交易的转发会暂时停止,只有等待第四节点重新上线后,交易才能转发到第二节点的交易池。可见,上述交易转发过程容易受单个节点上线或下线的影响,容错性较差,导致交易无法被快速地传递给对应的交易池。
发明内容
本发明实施例提供一种交易路由方法、装置及计算机可读存储介质,可以保证交易的转发过程不受单个节点上线或下线的影响,容错性强,使得交易能够被快速传递给对应的交易池。
第一方面,本发明实施例提供了一种交易路由方法,应用于区块链网络,所述区块链网络包括多个共识节点,所述多个共识节点中的每个共识节点维护各自对应的交易池,所述方法包括:
第一共识节点在接收到交易数据时,确定所述交易数据对应的目标交易池,所述第一共识节点为所述多个共识节点中的任意一个。
在所述第一共识节点的交易池不是所述目标交易池时,所述第一共识节点根据所述目标交易池的最短前缀从多个路由转发表中获取第二交易池的地址,其中,所述多个路由转发表包括字典树的多个子树中每个子树对应的路由转发表,所述字典树包括多个叶子节点,所述多个叶子节点中的每个叶子节点对应表示一个共识节点的交易池,所述第二交易池对应的叶子节点位于所述多个子树中包括所述目标交易池对应的叶子节点的子树中,所述多个子树是以第一叶子节点为基准对所述字典树从根节点开始拆分得到的,且所述每个子树均不包括所述第一叶子节点,所述第一叶子节点对应表示所述第一共识节点的交易池,所述多个路由转发表中的每个路由转发表用于记录对应子树中预设数量的叶子节点对应表示的交易池的地址。
所述第一共识节点向所述第二交易池的地址对应的共识节点发送所述交易数据。
第二方面,本发明实施例提供了一种交易路由装置,应用于区块链网络中的第一共识节点,所述区块链网络包括多个共识节点,所述第一共识节点为所述多个共识节点中的任意一个,所述多个共识节点中的每个共识节点维护各自对应的交易池,所述装置包括:
接收模块,用于接收交易数据。
确定模块,用于当所述接收模块接收到交易数据时,确定所述交易数据对应的目标交易池。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于腾讯科技(深圳)有限公司,未经腾讯科技(深圳)有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202010351450.0/2.html,转载请声明来源钻瓜专利网。
- 上一篇:一种高精度额温枪
- 下一篇:一种锚杆安装力矩定量控制及随检装置