[发明专利]优化输入输出负载的RAID-6横向斜向校验编码及解码方法在审

专利信息
申请号: 201510289990.X 申请日: 2015-05-31
公开(公告)号: CN104866243A 公开(公告)日: 2015-08-26
发明(设计)人: 吴晨涛;过敏意;李颉;何绪斌;冯博;黄洵松 申请(专利权)人: 上海交通大学
主分类号: G06F3/06 分类号: G06F3/06;G06F11/10
代理公司: 上海思微知识产权代理事务所(普通合伙) 31237 代理人: 席虹岩
地址: 200240 *** 国省代码: 上海;31
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 优化 输入输出 负载 raid 横向 校验 编码 解码 方法
【权利要求书】:

1.一种优化输入输出负载的RAID-6横向斜向校验编码方法,其特征在于,包括:

用一个p-1行p-1列的方阵来表示规模为p-1的磁盘阵列,其中p是任意给定的大于2的质数,其中,方阵中的每一列表示一个磁盘,方阵中的每个元素表示磁盘上一个定长的存储空间;

在所述方阵的主对角线存放横向校验块,副对角线存放反斜向校验块,方阵的剩余元素存放数据块,主对角线为横向校验链,副对角线为反斜向校验链。

2.如权利要求1所述的优化输入输出负载的RAID-6横向斜向校验编码,其特征在于,在所述方阵的主对角线存放横向校验块,副对角线存放反斜向校验块,方阵的剩余元素存放数据块包括:

根据横向和反斜向校验的计算公式在所述方阵的主对角线和副对角线之外的元素位置存放数据块;

根据所述横向和反斜向校验的计算公式,计算出所有横向校验块和反斜向校验块,并将所述横向校验块存放入所述方阵的主对角线上的对应的元素位置,将所述反斜向校验块存放入所述方阵的副对角线上的对应的元素位置。

3.如权利要求2所述的优化输入输出负载的RAID-6横向斜向校验编码,其特征在于,所述横向校验的计算公式如下:

其中,Ci,i表示横向校验块,Ci,j表示方阵中第i行第j列的元素,0≤i,j≤p-2。

4.如权利要求3所述的优化输入输出负载的RAID-6横向斜向校验编码,其特征在于,所述反斜向校验的计算公式如下:

(j≠p-2-i且j≠<p-3-2i>p),其中,Ci,p-2-i表示反斜向校验,表示方阵中第<2i+j+2>p行第j列的元素,<2i+j+2>p表示将2i+j+2的值对p取模。

5.如权利要求1所述的优化输入输出负载的RAID-6横向斜向校验解码方法,其特征在于,包括:

当磁盘阵列的最多2个盘失效时,根据方阵中的横向和反斜向校验链恢复失效元素。

6.如权利要求1所述的优化输入输出负载的RAID-6横向斜向校验解码方法,其特征在于,当磁盘阵列的1个盘失效时,根据方阵中的横向和反斜向校验链恢复失效元素包括:

读取方阵中的横向和反斜向校验链上的存活元素,计算存活元素的异或之和,将存活元素的异或之和作为失效元素的值。

7.如权利要求1所述的优化输入输出负载的RAID-6横向斜向校验解码方法,其特征在于,当磁盘阵列的2个盘失效时,根据方阵中的横向和反斜向校验链恢复失效元素包括:

步骤一,寻找位于失效的磁盘上且是所在反斜向校验链上唯一缺失的元素作为起始元素;

步骤二,通过所述反斜向校验链对所述起始元素进行恢复;

步骤三,当所述起始元素被恢复后,得到所述起始元素所在横向校验链上且位于失效盘上的一个第二元素,则通过所述横向校验链对所述第二元素进行恢复;

步骤四,判断失效的磁盘上是否还有待恢复的元素,

若有,将所述第二元素的所在反斜向校验链上下一个待恢复的元素替换为新的起始元素后转到步骤二;

若无,则结束。

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

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

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

×

专利文献下载

说明:

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

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

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

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

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

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

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

钻瓜专利网在线咨询

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

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