一种基于写重定向的纠删码存储重构优化方法
【专利摘要】本发明公开了一种基于写重定向的纠删码存储重构优化方法,将写入失效数据节点的数据重定向到由存活节点空余空间所组成的RS阵列,将数据重定向过程与包括失效数据节点的重构、重定向数据的迁移以及迁移所引起的校验数据更新的数据迁移过程分开处理,降低二者对磁盘、内存、网络带宽等资源的竞争,在加速后台重构过程的同时,优化前台用户访问性能。
【专利说明】—种基于写重定向的纠删码存储重构优化方法
【技术领域】
[0001]本发明属于计算机存储领域,更具体地,涉及一种基于写重定向的纠删码存储重构优化方法。
【背景技术】
[0002]廉价冗余磁盘阵列RAID (Redundant Array of Independent Disk)是将多个磁盘进行连接,构成具有一定容错能力的存储设备。构成RAID的多个磁盘驱动器在逻辑上可以看成是一个磁盘驱动器,各个磁盘可以同时工作,提高I/O并行性。RAID大多提供一定的校验技术,在一定数量的磁盘数据丢失的情况下,解码出丢失数据,达到容错的目的。一般地,数据恢复操作和用户I/O相互影响。一方面,在丢失数据恢复的过程中,磁盘阵列的读写性能将降低;另一方面,相对于离线重构模式,在线重构的时间也将增加,原因在于用户I/O对磁盘、网络和内存等资源的竞争。另外,研究表明,RAID系统中的磁盘错误存在“爆发”式特性,即当一个磁盘失效后,同一系统中的其它磁盘失效的概率将增大;此外,在高负载强度的重构过程中,存活磁盘发生失效的概率将进一步提高。
[0003]如图1所示,在(k+r,k)纠删码存储集群中,含k个数据节点,r个校验节点。集群内数据分布示意图如图2所示。失效写(Missed Writes)表示往失效数据节点中写入数据。参看图3,失效写的传统处理过程如下:(1)接收用户写数据请求,得到所写分块数据在纠删码集群的具体位置(即某数据节点上的某偏移地址)和所写入数据(以下称为新数据);
(2)将新数据写入替代数据节点的相应磁盘位置;(3)从k-Ι个存活节点读取所对应的分块数据;(4)由该k-Ι个存活分块数据和新数据分块计算出其余r个节点对应位置分块数据,并发送至r个节点,该r个节点完成数据更新;(5)返回更新操作的结果(成功或失效)。图4给出该传统纠删码存储集群中数据写的流程图。
[0004]传统纠删码存储集群中的写失效数据过程存在以下问题:
[0005]1、写失效数据节点过程与失效数据重构过程同时进行,两个过程之间相互竞争网络带宽、磁盘、内存等资源,重构时间随之增加,从而降低了系统可靠性。
[0006]2、用户的写请求涉及失效数据恢复、新数据写入,以及校验数据更新等三方面操作,因此用户写请求的响应时间也会增大。
【发明内容】
[0007]针对传统失效写方法存在的不足,本发明提供一种纠删码存储中写失效数据节点的优化方法,其不仅能够保证失效数据节点的重构性能,而且能降低用户失效写的响应时间。
[0008]为实现以上发明目的,本发明采用以下技术方案:
[0009]一种基于写重定向的纠删码存储重构优化方法,包括数据重定向过程和数据迁移过程。
[0010]重定向过程包括以下步骤:[0011](Al)接收用户写失效数据节点的用户请求记录;
[0012](A2)将用户请求记录写入空余RS阵列数据区;
[0013](A3)更新空余RS阵列校验区域;
[0014](A4)返回用户写失效数据节点请求结果,判断用户请求是否结束,如果结束,则程序结束,否则转入步骤(Al)。[0015]数据迁移过程与重定向过程分开处理。数据迁移过程包括失效数据节点的重构、重定向数据的迁移,以及迁移数据所导致的校验更新三个子过程。重定向数据迁移过程包括以下步骤:
[0016](BI)判断纠删码存储集群中失效数据节点数据是否恢复完成。若恢复完成,则转入步骤(B6),否则转入步骤(B2);
[0017](B2)假设写入失效数据节点node的失效数据块是Di,」,记录其偏移地址为offset ;
[0018](B3)读取任意k个存活节点偏移位置为offset的数据块Dlij (I ! =i);
[0019](B4)从该k个存活分块数据解码出失效数据分块Di, j ;并将数据Di, j写入数据节点node的替代节点node’中偏移地址为offset的位置;
[0020](B5)判断失效节点的数据是否恢复完成。若没有完成,则转入至步骤(B2),否则转入步骤(B6);
[0021](B6)读取RS阵列中用户请求记录(包括node、offset、newdata等信息);
[0022](B7)从替代数据节点node’中偏移位置为offset处读取数据分块olddata ;
[0023](B8)在替代节点node’中偏移位置为offset处写入新数据分块newdata ;
[0024](B9)将新旧数据分块(olddata和newdata)发送至各校验节点,各校验节点利用新旧数据分块结合已有校验分块,采用校验数据更新算法实现校验数据的更新;
[0025](BlO)读取空闲RS阵列中下一条用户请求记录,并判断是否结束,若未结束,则转入至步骤(B6);否则转入步骤(BII)。
[0026](BH)数据迁移过程结束。
[0027]与现有失效写技术相比,本发明具有以下有益效果:
[0028]1、在重定向过程中,使用存活节点空余磁盘空间构成空余RS阵列,如步骤(Al)。将写入失效数据节点的数据重定向到该RS阵列中,如步骤(A3),并完成空闲RS阵列中的校验部分的更新,如步骤(A4)。这种由空闲磁盘区域构成的RS阵列能够提高重定向数据的可靠性。
[0029]2、在重定向过程中,将用户写入失效数据节点的数据重定向到空闲RS阵列中后,用户请求立即返回,如步骤(A5),缩短了用户请求的响应时间。
[0030]3、将重定向过程和数据迁移过程分开处理,两过程相互独立,减少了两个过程对内存、磁盘、网络带宽等资源的竞争,确保了重构1/0和用户1/0之间的相互独立,从整体上优化重构性能和用户响应时间。
【专利附图】
【附图说明】
[0031]参照下面的说明,结合附图,可以对本发明有最佳的理解。在附图中,相同的部分可由相同的标号表不。[0032]图1为(k+r,k)纠删码存储集群磁盘示意图。
[0033]图2为纠删码存储集群中各节点数据分块示意图。
[0034]图3为传统纠删码存储集群写数据示意图。
[0035]图4为传统纠删码存储集群写数据流程图。
[0036]图5为本发明纠删码存储集群写数据示意图。
[0037]图6为本发明纠删码存储集群重定向过程流程图。
[0038]图7为本发明纠删码存储集群数据迁移过程流程图。
[0039]图8为RS (9,6)编码实施例示意图。
【具体实施方式】
[0040]为了使本发明的目的、技术方案及优点更加清楚明白,以下结合附图及示例性实施例,对本发明进行进一步详细说明。应当理解,此处所描述的示例性实施例仅用以解释本发明,并不用于限定本发明的适用范围。
[0041]以下首先就本发明的技术术语进行解释和说明:
[0042]写惩罚:在写数据节点的过程中,由于数据节点中数据分块内容的改变,根据纠删码的编码存储方式,校验节点对应位置的数据分块也要随之改变,带来额外的校验节点的写操作。如图l(k+r,k)纠删码存储集群磁盘示意图所示,磁盘阵列包含k个数据节点,分别标记为“数据节点0”,“数据节点1”,……,“数据节点k-1” ;r个校验节点,分别标记为“校验节点0”,“校验节点1”,……,“校验节点r-1’。图2为图1对应各节点的数据分块示意图,Di.j表示数据节点i中偏移位置为j*512字节处的数据块,Pi,j-表示校验节点i中偏移位置为j*512字节处的数据块。数据节点中数据块D0.j,D1,j、……Dk-1,1和校验节点中数据块P0.j,P1,j、……、Pr-1,j构成一个条带。Po.j,P1,j、……、存放由D0.j,D1,j,……Dk-1,j编码得到的校验数据。写惩罚即为当Di,j (0〈=i〈k)中数据发生改变时,条带中校验节点数据Poj,P1,j……、Pr-1,j也随之发生改变,而带来额外的写操作。
[0043]偏移位置:数据分块的偏移位置为数据分块在低地址处的起始位置。如图2各节点数据分块示意图所示,数据分块的大小为512字节,则Dij的偏移位置为j*512字节。纠删码集群中的数据读写最小单位为数据分块,即512字节。
[0044]编解码过程:编码过程为根据所有数据节点中特定数据分块计算出同一条带中对应位置校验节点数据分块块的过程。在图2各节点数据分块示意图中,若用f表示计算过
程,贝1J编码过程可以表不为f (D0j , Dlj ,......,Dk-1,j)— (Po,j,P1,j,......,Pr-1,j)。解码过
程为编码过程的逆过程,即在存活节点(未失效的数据节点和校验节点)数量大于等于k的情况下,任意选取k个存活节点数据分块,计算出同一条带中其它节点数据分块的过程。
[0045]RS阵列:RS类纠删码为三大纠删码中的一种,具有很强的纠错能力,包括范德蒙码和柯西码两种编码方式。RS阵列即为使用RS类纠删码进行数据校验的磁盘阵列。
[0046]在本发明实施例中,选定m个存活节点,利用该m个节点的空余空间构成空余RS阵列,用于存储用户的请求。总体思路为:将写入失效数据节点的数据重定向到由存活节点空余空间所组成的RS阵列(以下称为重定向RS阵列)中,以保障重定向数据的可靠性。本发明将数据重定向过程(以下称之为重定向过程)与其后续过程(包括失效数据节点的重构、重定向数据的迁移,以及迁移所引起的校验数据更新,以下称之为数据迁移过程)分开处理,降低二者对磁盘、内存、网络带宽等资源的竞争,在加速后台重构过程的同时,优化前台用户访问性能。
[0047]如图3所示,为传统纠删码写数据过程示意图。其中,DO数据节点为失效数据节点,D0’为DO失效数据节点的替代节点。标有的数据块为失效数据块,标有“**”的数据块为用户请求写入的数据块。图中数字表示传统纠删码写过程的具体步骤。
[0048]如图5所示,为本发明纠删码存储集群写数据示意图。其中DO数据节点为失效数据节点,D0’为DO失效数据节点的替换节点。标有的数据块为失效数据块,标有“**”的数据块为用户请求写入的数据块。图中数字如“A1”、“A2”、“A3”为重定向过程步骤号码,图中数字为“Β1”、“Β2”、“Β3”等为数据迁移过程步骤号码。空余空间RS阵列为由存活节点空余空间构成的具有一定容错能力的磁盘阵列,整个空余RS阵列的起始偏移地址为baseoffset,即重定向的基准偏移量为baseoffset。
[0049]对于重定向过程,存储集群将用户请求的写失效节点的数据重定向至空余空间RS阵列之后,用户请求立即返回,并继续响应其它用户请求。用户写请求包括写数据的具体信息,如写数据节点编号node,写数据偏移地址offset,写数据大小size,和写入的新数据newdata。以下称用户写数据的具体信息为一条用户请求记录。
[0050]图6为本发明纠删码存储集群重定向过程流程图,如图所示,重定向过程步骤如下:
[0051](Al)接收用户写失效数据节点的用户请求记录。其中,所述用户请求记录包括写数据节点编号node,写数据偏移地址offset和写入的新数据newdata。
[0052]例如,应用访问请求命令为〈1,2,1,buffer〉,则表示从buffer中取出1*512字节的数据,从磁盘编号为I的数据节点中偏移位置为2*512字节的位置开始写入。
[0053](A2)将用户请求记录写入空余RS阵列数据区。具体为:假设选取k’ +r’个存活节点构成RAID5 (k,+r’,k’)阵列,RAID5阵列的起始偏移地址为baseoffset,则将用户请求记录写入RAID5 (k’+r’,k’)中数据分块,中,其中Di^表示数据节点i ‘中偏移位置为j’ *512字节处的数据块。
[0054](A3)更新空余RS阵列校验区。即根据新写入的数据,完成RAID5的写惩罚过程。
[0055](A4)返回用户写失效数据节点请求结果,判断用户请求是否结束,如果结束,则重定向过程结束,否则转入步骤(Al)。
[0056]图7为本发明纠删码存储集群数据迁移过程流程图,数据迁移过程步骤如下:
[0057](BI)判断纠删码存储集群中失效数据节点数据是否恢复完成。若恢复完成,则转入步骤(B6),否则转入步骤(B2);
[0058](B2)假设写入失效数据节点node的失效数据块是Di,」,记录其偏移地址为offset ;
[0059](B3)读取任意k个存活节点偏移位置为offset的数据块D1,」(I ! =i);
[0060](B4)从该k个存活分块数据解码出失效数据分块Di, j ;并将数据Di, j写入数据节点node的替代节点node’中偏移地址为offset的位置;
[0061](B5)判断失效节点的数据是否恢复完成。若没有完成,则转入至步骤(B2),否则转入步骤(B6);
[0062](B6)读取空余R S阵列中用户请求记录(包括node、offset、newdata等信息);[0063](B7)从替代数据节点node’中偏移位置为offset处读取数据分块olddata ;
[0064](B8)在替代节点node’中偏移位置为offset处写入新数据分块newdata ;
[0065](B9)将旧数据分块olddata和新数据分块newdata发送至各校验节点,各校验节点利用新旧数据分块结合已有校验分块,采用校验数据更新算法实现校验数据的更新;
[0066](BlO)读取空余RS阵列中下一条用户请求记录,并判断是否结束,若未结束,则转入至步骤(B6);否则转入步骤(BII)。
[0067](BH)数据迁移过程结束。
[0068]如图8所示,DO, Dl, D2,D3,D4,D5为数据节点,DO为失效数据节点,DO'为DO的
替代节点,PO,PI, P2为校验节点。图中a,b,c,d,e, f,g,h,i,j分别为各个节点偏移位置为2*512处开始1*512字节大小的数据分块。图中A,B,C,D,E为由D4,D5,PO,Pl,P2空闲区域在baseoffset偏移位置之后构成的RAID (5,3)阵列。用户发出一条〈0,2,I,buffer)的应用访问请求。该应用访问请求在两种不同的写过程中的操作过程如下所示:
[0069](I)传统纠删码存储集群中的操作为:
[0070]从buffer中取出1*512字节的数据(newdata),写入替代节点Dtl'偏移位置为2*512即图8中a所示位置。读取存活节点D1, D2, D3, D4, D5, D6 ψ 2*512字节偏移位置(即c, d, e, f, g, h)处数据,解码出失效节点D0中b处旧数据olddata,将新数据newdata和旧数据olddata发送至校验节点PO,P1,P2。PO,Pl,P2在位置h,i,j处进行更新。最后向用户返回操作结果。
[0071](2)本发明中的操作过程为:
[0072]第一步:将用户请求记录写入由空闲区域组成的RAID (5,3)阵列中的位置A。读取位置B,C中数据,将A,B, C中数据进行编码之后,将编码后数据写入位置D,E中。
[0073]第二步:用户写请求返回,继续监听用户请求。
[0074]第三步:读取〈C, d, e, f, g, h>位置数据分块,解码出位置b的旧数据(olddata),并将旧数据olddata写入替代节点D0’对应位置,即为图中位置a。
[0075]第四步:读取A位置旧数据olddata,在DQ’中位置a处写入新数据newdata。并将olddata和newdata发送至校验节点PO, Pl, P2。
[0076]第五步:P0,Pl, P2根据新旧数据和原始校验数据在位置h,i,j处进行数据更新。数据迁移过程完成。
[0077]总而言之,本发明具有以下的有益效果:
[0078]1、在重定向过程中,使用存活节点空余磁盘空间构成空余RS阵列,如步骤(Al)。将写入失效数据节点的数据重定向到该RS阵列中,如步骤(A3),并完成空闲RS阵列中的校验部分的更新,如步骤(A4)。这种由空闲磁盘区域构成的RS阵列能够提高重定向数据的可靠性。
[0079]2、在重定向过程中,将用户写入失效数据节点的数据重定向到空闲RS阵列中后,用户请求立即返回,如步骤(A5),缩短了用户请求的响应时间。
[0080]3、将重定向过程和数据迁移过程分开处理,两过程相互独立,减少了两个过程对内存、磁盘、网络带宽等资源的竞争,确保了重构1/0和用户1/0之间的相互独立,从整体上优化重构性能和用户响应时间。
[0081]以上所述仅为本发明的较佳实施例而已,并不用以限制本发明,凡在本发明的精神和原则之内所作的任何修改、等同替换和改进等,均应包含在本发明的保护范围之内。
【权利要求】
1.一种基于写重定向的纠删码存储重构优化方法,包括数据重定向过程和数据迁移过程,其中,数据重定向过程包括以下步骤: (Al)接收用户写失效数据节点的用户请求记录; (A2)将用户请求记录写入空余RS阵列数据区; (A3)更新空余RS阵列校验区; (A4)返回用户写失效数据节点请求结果,判断用户请求是否结束,如果结束,则重定向过程结束,否则转入步骤(Al); 数据迁移过程包括以下步骤: (BI)判断纠删码存储集群中失效数据节点数据是否恢复完成,若恢复完成,则转入步骤(B6),否则转入步骤(B2); (B2)假设写入失效数据节点node的失效数据块是Di,」,记录其偏移地址为offset,其中Dy表示数据节点i中偏移位置为j*512字节处的数据块; (B3)读取任意k个存活节点偏移位置为offset的数据块D1,」(I ! =i); (B4)从该k个存活分块数据解码出失效数据分块Dm,并将数据Dm写入数据节点node的替代节点node’中偏移地址为offset的位置; (B5)判断失效节点的数据是否恢复完成,若没有完成,则转入至步骤(B2),否则转入步骤(B6); (B6)读取空余RS阵列中的用户请求记录; (B7)从替代数据节点node’中偏移位置为offset处读取数据分块olddata ; (B8)在替代节点node’中偏移位置为offset处写入新数据分块newdata ; (B9)将旧数据分块olddata和新数据分块newdata发送至各校验节点,各校验节点利用新旧数据分块结合已有校验分块,采用校验数据更新算法实现校验数据的更新; (BlO)读取空余RS阵列中下一条用户请求记录,并判断是否结束,若未结束,则转入至步骤(B6);否则转入步骤(Bll); (Bll)数据迁移过程结束。
2.根据权利要求1所述的方法,所述用户请求记录包括写数据节点编号node,写数据偏移地址offset和写入的新数据newdata。
3.根据权利要求3所述的方法,所述步骤(A2)具体为:假设选取k’+r’个存活节点构成RAID5 (k,+r’,k’)阵列,RAID5阵列的起始偏移地址为baseoffset,则将用户请求记录写入RAID5 (k,+r’,k’)中数据分块Di,,/中。
【文档编号】G06F11/10GK103605582SQ201310616406
【公开日】2014年2月26日 申请日期:2013年11月27日 优先权日:2013年11月27日
【发明者】黄建忠, 曹强, 谢长生, 梁先海, 王艳群 申请人:华中科技大学