[发明专利]一种可容多错交叉循环卷积码的局部性修复编码方法有效

专利信息
申请号: 201810257383.9 申请日: 2018-03-27
公开(公告)号: CN108683422B 公开(公告)日: 2021-08-27
发明(设计)人: 王静;张雪飞;贺书磊;王淑霞;王甜甜 申请(专利权)人: 长安大学
主分类号: H03M13/11 分类号: H03M13/11;H04L29/08
代理公司: 西安恒泰知识产权代理事务所 61216 代理人: 李婷;周春霞
地址: 710064 陕西省*** 国省代码: 陕西;61
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 一种 可容多错 交叉 循环 卷积码 局部性 修复 编码 方法
【说明书】:

发明公开了一种可容多错交叉循环卷积码的局部性修复编码方法,该方法考虑到存储系统中存储的数据量大,存储节点数增多,若采用传统部分重复码构造局部性修复编码,当节点出现故障时,故障节点修复方案单一,修复过程中的磁盘I/O开销较大,同时系统的容错能力较低,为此在分布式存储系统中采用可容多错交叉循环卷积码,在修复故障节点过程中修复方案较多,磁盘I/O开销相对较低且提高了系统的容错能力。

技术领域

本发明属于计算机领域,涉及一种可容多错交叉循环卷积码的局部性修复编码方法。

背景技术

随着存储数据的爆炸性增长,存储系统规模也成倍增长,这意味着存储节点海量化,为了确保存储数据的可用性和可靠性,存储系统通常采用“复制”和“纠删码”策略,然而“复制”策略存储代价较高,需要存储大量副本数据确保系统较高的可靠性,“纠删码”策略在节点修复过程中带宽开销过大,需要存储系统具有较高的网络带宽。针对“复制”和“纠删码”策略存在的不足,提出了再生码,但再生码在故障节点修复过程中连接的节点数量较多,具有较高的磁盘I/O开销,且故障节点修复方案单一,不能满足当前海量化的存储节点要求,同时系统的容错能力较低,这使得存储系统中故障节点修复存在局限性。

发明内容

针对上述现有技术中存在的缺陷或不足,本发明的目的在于,提供一种可容多错交叉循环卷积码的局部性修复编码方法,该方法可以容许系统的多个节点同时出现故障,且故障节点的修复方案较多,同样降低了故障节点修复过程中的磁盘I/O开销。

为了实现上述目的,本发明采用如下技术方案:

一种可容多错交叉循环卷积码的局部性修复编码方法,该方法用于将原始文件M存储到分布式存储系统中的节点上,分布式存储系统中的节点至少包括2n个,其特征在于,包括以下步骤:

步骤1,将原始文件M分成k个原始数据块,对k个原始数据块采用(n,k) 系统MDS码进行编码,得到n个编码数据块c1,…,cn-1,cn

步骤2,将n个编码数据块复制2次,每个编码数据块形成3个副本;

步骤3,在分布式存储系统中随机选取n个节点作为n个数据节点 N1,...,Ni,...Nn

步骤4,将n个编码数据块的3个副本存储到选取的n个数据节点上;采用的方法如下:

对于数据节点Ni,当1≤i≤n-1时,,该数据节点Ni上存储的编码数据块是ci、ci+1和ci+2;当i=n时,该数据节点Ni上存储的编码数据块是cn、c1和c2

步骤5,在分布式存储系统中随机选取除去步骤3选取的n个数据节点以外的n个节点作为n个校验节点Nn+1,...,Nn+j...,N2n

步骤6,在n个编码数据块c1,…,cn-1,cn中选取两个编码数据块ca和cb进行异或编码操作,得到n个校验数据块ca,b;其中,1≤a≤n,b=a+1,当a=n时, b=1;

步骤7,将n个校验数据块分别存储到n个校验节点Nn+1,...,Nn+j...,N2n上,采用的方法如下:

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

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于长安大学,未经长安大学许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

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

×

专利文献下载

说明:

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

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

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

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

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

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

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

钻瓜专利网在线咨询

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

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