[发明专利]一种分布式存储系统的元数据同步方法、系统及设备有效
| 申请号: | 202210432189.6 | 申请日: | 2022-04-22 |
| 公开(公告)号: | CN115599747B | 公开(公告)日: | 2023-06-06 |
| 发明(设计)人: | 罗杰彬;徐文豪;王弘毅;张凯 | 申请(专利权)人: | 北京志凌海纳科技有限公司 |
| 主分类号: | G06F16/13 | 分类号: | G06F16/13;G06F16/178;G06F16/18;G06F16/182 |
| 代理公司: | 北京绘聚高科知识产权代理事务所(普通合伙) 11832 | 代理人: | 汪帆 |
| 地址: | 100086 北京*** | 国省代码: | 北京;11 |
| 权利要求书: | 查看更多 | 说明书: | 查看更多 |
| 摘要: | |||
| 搜索关键词: | 一种 分布式 存储系统 数据 同步 方法 系统 设备 | ||
1.一种分布式存储系统的元数据同步方法,其特征在于,所述方法包括:
通过共识协议集群确定元数据服务主节点和元数据服务从节点;
在发生元数据变更时,利用所述元数据服务主节点将元数据变更操作封装成变更操作日志;
将所述变更操作日志按序写入所述共识协议集群的segment;
在写入成功后,将所述变更操作日志及其对应的元数据更新到元数据主节点的本地存储引擎中;
当所述共识协议集群中有新的segment被创建或间隔预设时长时,按照预设同步规则将所述变更操作日志及其对应的元数据同步到所述元数据服务从节点的本地存储引擎中;
所述预设同步规则为:
在元数据服务从节点的本地存储引擎中获取最新的变更操作日志序号;
从共识协议集群中拉去所有的segment信息;
根据所述segment内部第一个变更操作日志的序号将所有的segment进行排序;
找到第一个不小于所述最新的变更操作日志序号的segment;
判断该segment是否是最后一个,且该segment的第一个日志的序号大于所述最新的变更操作日志序号;
若是,则将该segment的上一个segment作为目标segment;
若否,则将该segment作为目标segment;
从目标segment开始,同步所有segment的变更操作日志。
2.根据权利要求1所述的方法,其特征在于,所述通过共识协议集群确定元数据服务主节点和元数据服务从节点,包括:
在共识协议集群的同一个目录中为每个元数据服务节点创建一个node,并按照创建时间排序;
将排在首位的node对应的元数据服务节点确定为元数据服务主节点,其他的则确定为元数据服务从节点。
3.根据权利要求2所述的方法,其特征在于,所述方法还包括:
当所述元数据服务主节点发生故障或网络分区时,删除代表所述元数据服务主节点的node;
将当前排在首位的node对应的元数据服务节点确定为新的元数据服务主节点。
4.根据权利要求1所述的方法,其特征在于,在按照预设同步规则将所述变更操作日志及其对应的元数据同步到所述元数据服务从节点的本地存储引擎中后,所述方法还包括:
通过排在首位的node对应的元数据服务从节点对共识协议集群中已经同步到各元数据服务从节点的变更操作日志进行回收处理。
5.根据权利要求4所述的方法,其特征在于,所述排在首位的node对应的元数据服务从节点会定时执行变更操作日志回收操作。
6.根据权利要求4所述的方法,其特征在于,所述方法还包括:
当有新的元数据服务节点加入共识协议集群时,从其他元数据服务节点的本地存储引擎中同步全量元数据。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京志凌海纳科技有限公司,未经北京志凌海纳科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202210432189.6/1.html,转载请声明来源钻瓜专利网。
- 数据显示系统、数据中继设备、数据中继方法、数据系统、接收设备和数据读取方法
- 数据记录方法、数据记录装置、数据记录媒体、数据重播方法和数据重播装置
- 数据发送方法、数据发送系统、数据发送装置以及数据结构
- 数据显示系统、数据中继设备、数据中继方法及数据系统
- 数据嵌入装置、数据嵌入方法、数据提取装置及数据提取方法
- 数据管理装置、数据编辑装置、数据阅览装置、数据管理方法、数据编辑方法以及数据阅览方法
- 数据发送和数据接收设备、数据发送和数据接收方法
- 数据发送装置、数据接收装置、数据收发系统、数据发送方法、数据接收方法和数据收发方法
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置





