[发明专利]区块同步方法、区块链系统、设备和存储介质有效
申请号: | 202211064387.8 | 申请日: | 2022-09-01 |
公开(公告)号: | CN115174598B | 公开(公告)日: | 2022-12-27 |
发明(设计)人: | 张珂杰;黄方蕾;叶晨宇;尚璇;胡麦芳 | 申请(专利权)人: | 杭州趣链科技有限公司 |
主分类号: | H04L67/1095 | 分类号: | H04L67/1095 |
代理公司: | 深圳中一联合知识产权代理有限公司 44414 | 代理人: | 姚泽鑫 |
地址: | 310000 浙江省杭州市*** | 国省代码: | 浙江;33 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 区块 同步 方法 系统 设备 存储 介质 | ||
1.一种区块同步方法,其特征在于,应用于区块链系统,所述区块链系统包括多个共识节点VP和m个非共识节点NVP集群,所述多个VP中的m个VP与所述m个NVP集群一一对应,所述m个NVP集群中每个NVP集群包括一个第一NVP和至少一个第二NVP,所述第一NVP为与对应的VP进行通信的NVP,所述第一NVP与所述至少一个第二NVP中的每个第二NVP之间均具有网络路径,所述m为正整数,所述方法包括:
所述多个VP每完成对一个区块的共识并将所述区块添加至区块链后,所述m个VP中的每个VP向对应的NVP集群中的所述第一NVP发送携带有所述区块的第一消息;
所述m个NVP集群中每个NVP集群中的每个NVP若接收到所述第一消息,则将所述第一消息携带的所述区块存储至区块链,并向同一NVP集群中相邻的NVP发送所述第一消息。
2.如权利要求1所述的方法,其特征在于,所述m个VP中的每个VP向对应的NVP集群中的所述第一NVP发送携带有所述区块的第一消息之前,还包括:
所述m个NVP集群中任意的一个NVP集群通过动态选举的方式选举出主NVP,所述一个NVP集群中除主NVP之外的其他NVP为从NVP,所述一个NVP集群中的主NVP为所述第一NVP,所述一个NVP集群中的从NVP为所述第二NVP;
所述一个NVP集群中的所述第一NVP向对应的VP发送第一通知消息,所述第一通知消息用于指示发送所述第一通知消息的NVP已当选所在NVP集群的主NVP。
3.如权利要求2所述的方法,其特征在于,所述m个NVP集群中任意的一个NVP集群通过动态选举的方式选举出一个主NVP,包括:
所述一个NVP集群整体启动后,所述一个NVP集群中至少一个NVP中的每个NVP向同一NVP集群中的其他NVP广播携带自身的节点标识的第二消息,所述第二消息用于指示所述第二消息携带的节点标识所标识的NVP申请成为主NVP;
所述至少一个NVP中任意的一个NVP执行以下操作:
在广播所述第二消息后的第一预设时长内接收其他NVP广播的所述第二消息;
将自身的节点标识与在所述第一预设时长内接收到的其他NVP广播的所述第二消息携带的节点标识进行比较,以确定自身是否当选主NVP;
若确定自身当选主NVP,则每隔第二预设时长向同一NVP集群中的其他NVP发送第二通知消息,所述第二通知消息用于指示发送所述第二通知消息的NVP已当选所在NVP集群的主NVP,且用于指示接收所述第二通知消息的NVP为所在NVP集群的从NVP。
4.如权利要求3所述的方法,其特征在于,所述方法还包括:
所述一个NVP集群中任意的一个从NVP若在第三预设时长内未接收到所述第二通知消息,则向同一NVP集群中的其他NVP广播所述第二消息,所述第三预设时长大于或等于所述第二预设时长;
所述一个NVP集群中任意的一个NVP若接收到所述一个从NVP广播的所述第二消息,则在将自身的节点标识与所述一个从NVP广播的所述第二消息携带的节点标识进行比较后,确定所述一个从NVP不能当选主NVP的情况下,向同一NVP集群中的其他NVP广播所述第二消息;
所述一个NVP集群中任意的一个NVP执行以下操作:
在最新广播所述第二消息后的所述第一预设时长内接收其他NVP广播的所述第二消息;
将自身的节点标识与在所述第一预设时长内接收到的其他NVP广播的所述第二消息携带的节点标识进行比较,以确定自身是否当选主NVP;
若确定自身当选主NVP,则每隔所述第二预设时长向同一NVP集群中的其他NVP发送所述第二通知消息。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于杭州趣链科技有限公司,未经杭州趣链科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202211064387.8/1.html,转载请声明来源钻瓜专利网。