CN101236482A - 降级状态下处理数据的方法及独立冗余磁盘阵列系统 - Google Patents

降级状态下处理数据的方法及独立冗余磁盘阵列系统 Download PDF

Info

Publication number
CN101236482A
CN101236482A CNA2008101009332A CN200810100933A CN101236482A CN 101236482 A CN101236482 A CN 101236482A CN A2008101009332 A CNA2008101009332 A CN A2008101009332A CN 200810100933 A CN200810100933 A CN 200810100933A CN 101236482 A CN101236482 A CN 101236482A
Authority
CN
China
Prior art keywords
data
space
buffer memory
write
damage
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CNA2008101009332A
Other languages
English (en)
Other versions
CN101236482B (zh
Inventor
侯敏
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
New H3C Technologies Co Ltd
Original Assignee
Hangzhou H3C Technologies Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Hangzhou H3C Technologies Co Ltd filed Critical Hangzhou H3C Technologies Co Ltd
Priority to CN2008101009332A priority Critical patent/CN101236482B/zh
Publication of CN101236482A publication Critical patent/CN101236482A/zh
Application granted granted Critical
Publication of CN101236482B publication Critical patent/CN101236482B/zh
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Techniques For Improving Reliability Of Storages (AREA)

Abstract

本发明公开了降级状态下处理数据的方法及独立冗余磁盘阵列系统,通过将损坏空间的数据存入第一存储介质;当需要读写所述损坏空间的数据时,从所述第一存储介质中获得所述数据,使得对这些数据进行的读写操作的对象不再是损坏的空间,而是运行正常的第一存储介质,这样就可以按照正常的读写流程处理数据,进而能够有效提高独立冗余磁盘阵列系统在降级状态下的性能。

Description

降级状态下处理数据的方法及独立冗余磁盘阵列系统
技术领域
本发明涉及独立冗余磁盘阵列技术,尤指一种独立冗余磁盘阵列系统在降级状态下处理数据的方法以及一种独立冗余磁盘阵列系统。
背景技术
独立冗余磁盘阵列(RAID,Redundant Array of Independent Disks)是改善磁盘存储性能的有效方法之一。它将要存储的数据按一定规则分块,存放在多个盘上,利用多个盘的并行存取、并行传输来匹配带宽,以提高存取速度。同时,RAID还利用冗余数据来提高系统的可靠性。对主机来说它相当于一个快速大容量的磁盘。RAID目前分为7级:RAID0~RAID6,其中RAID1~RAID6采用冗余校验信息来提高系统的可靠性。
RAID系统包括RAID控制器、阵列缓存和多个磁盘。其中,磁盘用来存储数据;阵列缓存用来临时存放主机访问的数据,使主机对RAID系统的数据访问大多数通过缓存进行,以提高主机对RAID系统的数据访问速度。控制器用来控制阵列缓存以及磁盘的读写操作。
现以RAID5为例介绍RAID系统的工作情况。图1所示为RAID5的数据分布关系图。图示中的物理磁盘为真实存在的物理磁盘,一般是企业级硬盘,对最终用户来说一般是不可见。真实的物理磁盘被分割成很多段,每个段称为一个条块(Strip),不同物理磁盘上的相邻段组合形成连续的逻辑磁盘。每块物理磁盘上相邻的Strip组合形成一个条带(Stripe),每个Stripe都有一个校验块,用来存储该Stripe的奇偶校验信息,如图1中所示的P0~P3。RAID5通过奇偶校验来提供数据恢复的能力。
当对逻辑磁盘发出读命令后,RAID系统中的RAID控制器根据图1中的对应关系,找到读取的数据所在的物理磁盘,返回对应Strip中的数据。如果磁盘丢失或者损坏,例如图1中的物理磁盘1丢失,而此时需要读取D1中的数据,则需要通过RAID5的奇偶校验信息计算出D1中的数据并返回。具体的方法是读取这个Stripe上的其他Strip:D0、D2和P0,然后对这些Strip做奇偶校验,校验值就是D1的数据。
当对逻辑磁盘发出写命令时,控制器根据图1中的对应关系将数据写入对应的物理磁盘,并根据新写入的数据重新计算奇偶校验信息。当写入的磁盘丢失或者对应的写入空间发生故障,则不得不消耗更多的时间来计算奇偶校验信息,以弥补因丢失原数据而对计算奇偶校验信息的影响。
可见,RAID系统由于其冗余特性,在Stripe中的一个Strip出现损坏时,仍然可以对其继续进行读写操作。这种状态下的RAID系统成为处于降级(Degrade)状态的RAID系统。当RAID处于降级状态下时,其数据安全性很脆弱,所以一般都会添加一块磁盘替换发生故障的磁盘,通过校验把数据重新写入新加磁盘,使阵列恢复正常状态。这个操作一般称为阵列重建(Rebuild)。由于阵列重建需要占用RAID系统的大量资源,因此用户都选择在业务空闲的时候进行重建。在此之前,不得不在降级状态下继续使用RAID系统。
虽然,用户还能够在RAID系统处于降级状态时,继续使用RAID读写数据,但是由于在读写过程中,将耗费大量额外资源以弥补丢失数据的问题,因此降级状态下RAID系统的性能将大幅度下降,特别是对于数据库应用中存在大量小数据块随机读写的情况下,性能将下降更明显。
发明内容
有鉴于此,本发明提供了一种降级状态下处理数据的方法,应用本发明所提供的方法能够提高RAID系统在降级状态下的读写性能。
一种独立冗余磁盘阵列系统在降级状态下处理数据的方法,该方法包括:
将独立冗余磁盘阵列系统中损坏空间的数据存入第一存储介质;
当需要读写所述损坏空间的数据时,从所述第一存储介质中获得所述数据。
本发明提供了一种独立冗余磁盘阵列系统,该RAID系统能够提高在降级状态下的读写性能。
一种独立冗余磁盘阵列系统,该系统包括:
RAID控制器,用于控制将RAID系统中损坏空间上的数据存入第一存储介质;当需要读写所述损坏空间的数据时,从第一存储介质中获得所述数据;
第一存储介质,用于存储损坏空间上的数据。
本发明所提供的一种在降级状态下处理数据的方法及RAID系统,通过将损坏空间的数据存入第一存储介质;当需要访问该数据时,直接从所述第一存储介质中获得所述数据,使得对这些数据进行的读写操作的对象不再是损坏的空间,而是运行正常的第一存储介质,这样就可以按照正常的读写流程处理数据,进而能够有效提高RAID系统在降级状态下的性能。
附图说明
图1为现有技术RAID5系统的数据分布关系示意图;
图2为本发明的方法示例性流程图;
图3为本发明的系统示例性结构图;
图4为本发明第一实施例读操作处理流程图;
图5为本发明第一实施例写操作处理流程图;
图6为本发明第一实施例RAID系统的结构图;
图7为本发明第二实施例RAID系统的结构图。
具体实施方式
在本发明实施例的技术方案中,为了提高RAID系统在降级状态下的性能,可以将磁盘上损坏空间的数据存入第一存储介质;在需要访问损坏空间的数据时,则直接访问第一存储介质来获得这些数据。本发明的技术方案,由于将损坏空间上的数据转移至为损坏的空间上,因此对这些数据进行读写操作时,操作的对象不再是损坏的空间,这样就可以按照正常的读写流程处理数据,因此能够提高RAID系统在降级状态下的性能。
参见图2,图2为本发明的方法示例性流程图,包括:在步骤201中,将独立冗余磁盘阵列系统中损坏空间的数据存入第一存储介质;在步骤202中,当需要读写所述损坏空间的数据时,从所述第一存储介质中获得所述数据。
另外,参见图3,图3为本发明的RAID系统示例性结构图,包括:RAID控制器,用于将RAID系统中损坏空间上的数据存入第一存储介质;当需要读写所述损坏空间的数据时,从第一存储介质中获得所述数据;第一存储介质,用于存储损坏空间上的数据。其中,损坏空间可能为磁盘中的一部分,也可以是整个磁盘。
在本发明实施例的技术方案中,用来存储损坏磁盘上数据的第一存储介质可以是RAID系统中的阵列缓存、新增磁盘、或磁盘对应中的校验块。
现针对上述三种情况分别列举实施例,对本发明的技术方案进行详细说明。
实施例一
本实施例主要介绍第一存储介质为RAID系统阵列缓存的情况。RAID系统中的阵列缓存用来临时存放主机访问的数据,在访问数据时,RAID控制器通常先访问阵列缓存,如果阵列缓存内未存储时再访问磁盘,以提高主机对RAID系统的数据访问速度。
在使用阵列缓存作第一存储介质时,可以在获知磁盘上出现损坏空间时,通过校验恢复损坏空间上的数据,将恢复数据保存至阵列缓存,供访问时使用。另外,由于阵列缓存会缓存部分数据,并且在进行读写操作时对缓存内的数据进行更新。因此可以借助阵列缓存读写时进行的更新操作,在读写过程中,逐步将损坏空间中的数据写入阵列缓存,将缓存中非损坏空间的数据移出缓存,实现将损坏空间上的数据保存至阵列缓存。
这里,由于阵列缓存中会保存部分数据,因此在访问数据时,所要访问的数据为损坏空间的数据、并且未保存在阵列缓存内,再将该数据写入阵列缓存。访问数据的操作包括读操作和写操作,阵列缓存对应读写操作,分为读缓存和写缓存。其中,读缓存用来存储从磁盘中读取的数据,写缓存用来存储写入磁盘的数据。在将数据写入磁盘时,通常将数据先写入写缓存,然后再由写缓存写入磁盘。这样,将数据写入写缓存后,RAID控制器就可向返回写入成功的响应,以减少写操作的响应时间。
当执行读操作时,在所要读取的数据中存在损坏空间的数据、并且未保存在阵列缓存内的情况下,将读取的损坏空间的数据写入阵列缓存的读缓存内;当执行写数据时,在数据写入的空间为损坏空间、并且该数据未保存在阵列缓存内的情况下,将该数据写入所述阵列缓存的写缓存内。
参见图4和5,图4和5分别为对应读操作和写操作更新阵列缓存的流程图,现分别介绍如下。
参见图4,图4为本发明实施例在读操作时更新阵列缓存的流程图。
在步骤401中,RAID系统中的控制器收到读命令。
在步骤402中,根据读命令中携带的标识信息,判断读缓存是否命中,如果是,则从读缓存中返回所需数据,结束当前处理流程;否则,执行步骤403。
其中的标识信息用于标识数据块在RAID系统中的位置,可包括数据块在磁盘中保存的逻辑地址、同一个数据块保存在缓存中的缓存地址以及逻辑地址和缓存地址之间的映射关系等内容中的一项或几项。在读缓存和写缓存中均会保存标识信息表,用来确定自身是否保存了相关数据。
在步骤403中,根据读命令中携带的标识信息,判断写缓存是否命中,如果是,则从写缓存中返回所需数据,结束当前处理流程;否则,执行步骤404。
在步骤404中,RAID控制器下发命令读取磁盘,从磁盘中获取所需数据,执行步骤405。
这里,如果需要读取的数据为磁盘上损坏空间的数据,则获取的数据通过校验得到;如果需要读取的数据不为磁盘损坏空间的数据,则直接从磁盘上读取。
在步骤405中,判断当前读取的数据中是否损坏空间的数据,如果是,执行步骤406;否则,结束当前处理流程。
在RAID系统中,如果磁盘发生损坏,RAID控制器则会记录损坏空间的具体位置信息。RAID控制器可以依据当前读命令中携带的标识信息以及记录的损坏空间的位置信息确定当前读取的数据中是否有损坏空间的数据。
在步骤406中,将损坏空间上的数据写入读缓存,结束当前处理流程。
在阵列缓存中,损坏空间上的数据具有比非损坏空间数据高的优先级,在阵列缓存可用空间不足时,按照阵列缓存策略释放阵列缓存内保存的非损坏空间的数据,将所述损坏空间的数据写入释放空间。在将非损坏空间的数据写入阵列缓存时,仅将该数据写入阵列缓存内未被损坏空间数据占用的空间中。
这里,将损坏空间的数据写入读缓存的方式可以是,先考虑读缓存中是否有空块,在有空块的情况下,先写入空块;再考虑读缓存中的非损坏空间的数据,用损坏空间的数据替换非损坏空间的数据;最后,在读缓存内不存在非损坏空间的数据,按照阵列缓存策略进行替换。
具体为,先将当前损坏空间的数据写入读缓存中的空块;在读缓存中没有空块或者空块容量不足时,再按照阵列缓存策略用当前损坏空间上的数据或剩下未写入的数据,更新读缓存内已经保存的非损坏空间的数据;最后在读缓存中没有保存的非损坏空间的数据或者对应容量不足的情况下,按照阵列缓存策略用当前损坏空间上的数据或剩下未写入的数据,更新读缓存内已经保存的损坏空间的数据。
另外,对于当前读取的非损坏空间的数据,可以按照上述处理流程,执行不将非损坏空间的数据写入读缓存的操作;也可以在不影响读缓存中已经保存的损坏空间的数据的情况下,将当前读取的非损坏空间的数据写入读缓存,以有效利用缓存空间,提高读写效率。具体可以是:对于当前读取的非损坏空间的数据,可以先将当前非损坏空间的数据写入读缓存中的空块;在读缓存中没有空块或者空块容量不足时,再按照阵列缓存策略用当前非损坏空间上的数据或者剩下未写入的数据更新读缓存内已经保存的非损坏空间的数据;在读缓存中已经没有保存的非损坏空间的数据或者对应容量不足的情况下,对于当前非损坏空间的数据或者剩下未写入的数据则不再进行处理。
这里所使用的阵列缓存策略可以是阵列缓存会按照访问频率优先(LFU,Least Frequency Used)、最短访问优先(LRU,Least Recently Used)及最近访问频率优先(LRFU,Least Recently Frequency Used)等策略。
在本实施例的流程中,在步骤401和404中之所以未进行当前读取数据是否为损坏空间上的数据的判断,主要是因为无论该数据是否为损坏空间上的数据,这个数据已经保存在阵列缓存中,进而不需要对这类处理进行处理。
参见图5,图5为本发明实施例在写操作时更新阵列缓存的流程图。
在步骤501中,RAID系统中的控制器收到写命令。
在步骤502中,根据写命令中携带的标识信息,判断读缓存是否命中,如果是,执行步骤503;否则,执行步骤509。
在步骤503中,根据写命令中携带的标识信息,判断写缓存是否命中,如果是,执行步骤504;否则,执行步骤505。
在步骤504中,更新写缓存,执行步骤508。
在步骤505中,判断当前写入的数据中是否存在要写入RAID系统中损坏空间的数据,如果是,则执行步骤506;否则,执行步骤507。
其中,判断当前写入数据中是否存在要写入损坏空间的数据的方法,与读流程中步骤405的方法相同。即依据当前读命令中携带的标识信息以及记录的损坏空间的位置信息确定当前写入的数据中是否存在写入损坏空间的数据。
在步骤506中,将要写入损坏空间上的数据写入写缓存,由写缓存处理写入对应磁盘;对于当前写入数据中写入非损坏空间的数据,不写入写缓存,直接执行写入磁盘操作;执行步骤508。
其中,将要写入损坏空间的数据写入写缓存的操作,也可以与写入读缓存的操作类似,先将当前要写入损坏空间的数据写入写缓存中的空块;在读缓存中没有空块或者空块容量不足时,再按照阵列缓存策略用当前写入损坏空间上的数据或剩下未写入的数据,更新写缓存内已经保存的非损坏空间的数据;最后在读缓存没有保存的非损坏空间的数据或者对应容量不足的情况下,按照阵列缓存策略用当前损坏空间上的数据或剩下未写入的数据,更新写缓存内已经保存的损坏空间的数据。
在步骤507中,不将当前写入数据写入写缓存,直接执行写入磁盘操作。
这里,对于步骤506中当前写入数据中剩下写入非损坏空间的数据,以及本步骤中对应非损坏空间的数据,在不影响写缓存中已经保存的损坏空间的数据的情况下,按照一定的策略将当前对应非损坏空间的数据写入写缓存,以有效利用缓存空间,提高读写效率。具体可以是:对于当前对应非损坏空间的数据,可以先将当前非损坏空间的数据写入写缓存中的空块;在写缓存中没有空块或者空块容量不足时,再按照阵列缓存策略用对应非损坏空间上的数据或者剩下未写入的数据更新写缓存内已经保存的非损坏空间的数据;在读写存中没有保存非损坏空间的数据或者对应容量不足的情况下,则不降对应非损坏空间的数据或者剩下未写入的数据写入写缓存。
在步骤508中,更新读缓存,结束当前处理流程。
在步骤509中,根据写命令中携带的标识信息,判断写缓存是否命中,如果是,执行步骤510;否则,执行步骤511。
在步骤510中,更新写缓存,结束当前处理流程。
另外,步骤511~513的具体实现与步骤505~507相同,在此不再详述。
参见图6,图6为本发明实施例系统的结构图。在本实施例中第一存储介质为RAID系统中的阵列缓存,对应的RAID系统包括:RAID控制器、阵列缓存和磁盘。其中,RAID控制器,用于控制将RAID系统中损坏空间上的数据存入阵列缓存;当需要访问所述数据时,从阵列缓存中获得所述数据。所述RAID控制器,用于访问数据,当所要访问的数据为损坏空间的数据、并且未保存在阵列缓存内,将该数据写入阵列缓存。
所述阵列缓存包括:读缓存和写缓存。所述RAID控制器,用于在读数据时,所要读取的数据中存在损坏空间的数据、并且未保存在阵列缓存内,将读取的损坏空间的数据写入阵列缓存的读缓存内;在写数据时,当数据写入的空间为损坏空间、并且该数据未保存在阵列缓存内,将该数据写入所述阵列缓存的写缓存内。
具体的,所述RAID控制器,用于在阵列缓存内存在空块时,将当前损坏空间的数据写入阵列缓存的空块;在阵列缓存没有空块或者空块容量不足时,按照阵列缓存策略用当前损坏空间上的数据或剩下未写入的数据,更新阵列缓存内已经保存的非损坏空间的数据;在阵列缓存内没有保存非损坏空间的数据或者对应容量不足时,按照阵列缓存策略用当前损坏空间上的数据或剩下未写入的数据,更新阵列缓存内已经保存的损坏空间的数据。
另外,RAID控制器,进一步用于在访问数据时,所访问的数据未保存在阵列缓存内、并且不为损坏空间的数据,在不影响阵列缓存内已经保存的损坏空间数据的情况下将该数据写入阵列缓存。
另外,RAID控制器,还可以在获知磁盘上出现损坏空间时,将该损坏空间上的数据保存至新增磁盘。
经过实验证明,以一个10T的RAID5系统,阵列缓存容量为100G,在正常状态下阵列缓存的命中率有20%。那么当没有使用本技术之前,在RAID5系统阵列降级后,随机性能约降低到原性能的50%;使用本实施例的技术方案后,如果100G的阵列缓存都用来做损坏控制的缓存,随机性能只降低到原性能的80%。可见,相对于现有技术,本发明能够有效的提高RAID5系统的性能。
实施例二
本实施例主要介绍第一存储介质为新增磁盘的情况。
在使用新增磁盘作第一存储介质时,可以在获知磁盘上出现损坏空间时,通过校验恢复损坏空间上的数据,将恢复数据保存至阵列缓存,供访问时使用。另外,也可以在读取磁盘上损坏空间的数据或者向损坏空间写入数据时,将当前操作对应的数据写入新增磁盘,供访问时使用。
在进行读操作时,判定得到当前读操作磁盘的存储空间为损坏空间时,将从读缓存、或写缓存、或从磁盘中读取的数据存入新增磁盘。判断当前读操作对应的数据是否是损坏空间上的数据的时机,可以是RAID控制器收到读命令时、或者在返回读操作对应的数据时,或者读操作的其他阶段执行。
在进行写操作时,判定得到当前写操作对应磁盘上的损坏空间时,将当前待写入损坏空间的数据,写入新增磁盘。这里,执行判断的时机,可以是RAID控制器收到写命令或写操作的其他阶段执行。
当将损坏空间的数据写入新增磁盘后,在RAID控制器内记录该数据对应的损坏空间,以及该数据在新增磁盘上位置信息,以备后续查找。这里,为了区别损坏空间上的数据是否已被校验,可以将经过校验的损坏空间称为已校验损坏空间,将未经过校验的损坏空间称为为校验损坏空间。
在新增磁盘后,在读写阵列缓存之前,可以先根据记录的已校验的损坏空间,判断所需数据是否在新增磁盘上,如果在新增磁盘上,则根据对应的位置信息查找得到对应的数据,则不必再读取阵列缓存以及根据原磁盘校验得到。其中,记录已校验损坏空间的方法可以是:在RAID控制器内记录一个位图或者索引来经过校验的Strip。通过读取这个位图或者索引来确定对应的Strip是否经过校验。
在用该新增磁盘同步损坏空间所在的磁盘、重建RAID系统时,可以根据记录的已校验的损坏空间,仅对没有记录的损坏空间、以及非损坏空间进行校验,并写入新增磁盘。
参见图7,图7为本发明实施例系统的结构图。在本实施例中第一存储介质为新增磁盘,RAID系统包括:RAID控制器、阵列缓存、原磁盘和新增磁盘。
具体的,RAID控制器,用于控制将RAID系统中损坏空间上的数据存入新增磁盘;当需要访问所述数据时,从新增磁盘中获得所述数据。所述RAID控制器,进一步用于记录数据被写入新增磁盘的损坏空间;在使用所述新增磁盘同步损坏空间所在的磁盘时,根据记录的损坏空间,仅将磁盘中未记录空间的数据同步至所述新增磁盘。
具体的,所述RAID控制器可以在访问数据时,确定所要访问的数据为损坏空间的数据,将该数据存入新增磁盘;或者,在获知磁盘上出现损坏空间时,将该损坏空间上的数据保存至新增磁盘。
其中RAID控制器、阵列缓存和原磁盘之间的链接关系,与现有技术中的相同,在此不再详述。
实施例三
本实施例主要介绍第一存储介质为磁盘中校验块的情况。
在使用磁盘中的校验块作第一存储介质时,可以在获知磁盘上出现损坏空间时,通过校验恢复损坏空间上的数据,并将数据保存至磁盘中校验块,具体的可以是损坏空间对应条带中的校验块。另外,也可以在读取磁盘上损坏空间的数据或者向损坏空间写入数据时,将当前操作对应的数据写入新增磁盘,供访问时使用。具体的方式与实施例二的相同,在此不再详述。
当将损坏空间中的数据对应条带的校验块后,需要在RAID控制器内修改数据对应的存储地址,以备后续查找使用。
本实施例中RAID系统的结构与实施例一中系统结构图相同,只是在本实施例中第一存储介质为RAID系统磁盘中的校验块。
具体,RAID控制器可以在访问数据时,确定所要访问的数据为损坏空间的数据,将该数据存入RAID系统磁盘中的校验块;或者,在获知磁盘上出现损坏空间时,将该损坏空间上的数据写入至RAID系统磁盘中的校验块。
本发明实施例的技术方案适用于RAID1-6的系统中。本发明实施例的技术方案,通过将磁盘上损坏空间的数据存入第一存储介质;在需要访问损坏空间的数据时,直接访问第一存储介质来获得这些数据。由于将损坏空间上的数据转移至未损坏的空间上保存,避免了为获得数据而对损坏的空间重复执行校验的操作,因此提高了RAID系统在降级状态下的处理性能。
以上所述仅为本发明的较佳实施例而已,并不用以限制本发明,凡在本发明的精神和原则之内,所做的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。

Claims (22)

1、一种独立冗余磁盘阵列系统在降级状态下处理数据的方法,其特征在于,该方法包括:
将独立冗余磁盘阵列系统中损坏空间的数据存入第一存储介质;
当需要读写所述损坏空间的数据时,从所述第一存储介质中获得所述数据。
2、根据权利要求1所述的方法,其特征在于,所述将损坏空间的数据存入第一存储介质为:将所述数据存入阵列缓存。
3、根据权利要求2所述的方法,其特征在于,所述将损坏空间的数据存入阵列缓存包括:
在对损坏空间进行数据读写,所述数据未保存在阵列缓存内时,将该数据写入阵列缓存。
4、根据权利要求3所述的方法,其特征在于,在对损坏空间进行数据读写,所述数据未保存在阵列缓存内时,将该数据写入阵列缓存包括:
在读数据时,所要读取的数据中存在损坏空间的数据、并且未保存在阵列缓存内,将读取的损坏空间的数据写入阵列缓存的读缓存内;
在写数据时,当数据写入的空间为损坏空间、并且该数据未保存在阵列缓存内,将该数据写入所述阵列缓存的写缓存内。
5、根据权利要求4所述的方法,其特征在于,所述将损坏空间的数据写入阵列缓存包括:
在阵列缓存可用空间不足时,按照阵列缓存策略释放阵列缓存内保存的非损坏空间的数据,将所述损坏空间的数据写入释放空间。
6、根据权利要求3或4所述的方法,其特征在于,该方法进一步包括:
在将非损坏空间的数据写入阵列缓存时,仅将该数据写入阵列缓存内未被损坏空间数据占用的空间中。
7、根据权利要求1所述的方法,其特征在于,所述将损坏空间的数据存入第一存储介质为:将所述数据写入新增磁盘。
8、根据权利要求7所述的方法,其特征在于,该方法进一步包括:
记录数据被写入新增磁盘的损坏空间;
在使用所述新增磁盘同步损坏空间所在的磁盘时,根据记录的损坏空间,仅将磁盘中未记录空间的数据同步至所述新增磁盘。
9、根据权利要求1所述的方法,其特征在于,所述将损坏空间上的数据存入第一存储介质为:将所述数据写入RAID系统内磁盘的校验块。
10、根据权利要求7、8或9所述的方法,其特征在于,所述将独立冗余磁盘阵列系统中损坏空间的数据存入第一存储介质包括:
在访问数据时,确定所要访问的数据为损坏空间的数据,将该数据存入第一存储介质。
11、根据权利要求2、7、8或9所述的方法,其特征在于,所述将损坏空间上的数据存入第一存储介质包括:
在获知磁盘上出现损坏空间时,将该损坏空间上的数据保存至第一存储介质。
12、一种独立冗余磁盘阵列系统,其特征在于,该系统包括:
RAID控制器,用于控制将RAID系统中损坏空间上的数据存入第一存储介质;当需要读写所述损坏空间的数据时,从第一存储介质中获得所述数据;
第一存储介质,用于存储损坏空间上的数据。
13、根据权利要求12所述的RAID系统,其特征在于,所述第一存储介质为RAID系统中的阵列缓存。
14、根据权利要求13所述的RAID系统,其特征在于,
所述RAID控制器,用于在对损坏空间进行数据读写,所述数据未保存在阵列缓存内时,将该数据写入阵列缓存。
15、根据权利要求14所述的RAID系统,其特征在于,所述阵列缓存包括:读缓存和写缓存;
所述RAID控制器,用于在读数据时,所要读取的数据中存在损坏空间的数据、并且未保存在阵列缓存内,将读取的损坏空间的数据写入阵列缓存的读缓存内;在写数据时,当数据写入的空间为损坏空间、并且该数据未保存在阵列缓存内,将该数据写入所述阵列缓存的写缓存内。
16、根据权利要求14或15所述的RAID系统,其特征在于,
所述RAID控制器,用于在阵列缓存可用空间不足时,按照阵列缓存策略释放阵列缓存内保存的非损坏空间的数据,将所述损坏空间的数据写入释放空间。
17、根据权利要求14或15所述的RAID系统,其特征在于,
所述RADI控制器,进一步用于在将非损坏空间的数据写入阵列缓存时,仅将该数据写入阵列缓存内未被损坏空间数据占用的空间中。
18、根据权利要求12所述的RAID系统,其特征在于,
所述第一存储介质为新增磁盘。
19、根据权利要求18所述的RAID系统,其特征在于,
所述RAID控制器,进一步用于记录数据被写入新增磁盘的损坏空间;在使用所述新增磁盘同步损坏空间所在的磁盘时,根据记录的损坏空间,仅将磁盘中未记录空间的数据同步至所述新增磁盘。
20、根据权利要求12所述的方法,其特征在于,
所述第一存储介质为:RAID系统磁盘中的校验块。
21、根据权利要求18、19或20所述的RAID系统,其特征在于,
所述RAID控制器,用于在访问数据时,确定所要访问的数据为损坏空间的数据,将该数据存入第一存储介质。
22、根据权利要求13、18、19或20所述的RAID系统,其特征在于,
所述RAID控制器,用于在获知磁盘上出现损坏空间时,将该损坏空间上的数据保存至第一存储介质。
CN2008101009332A 2008-02-26 2008-02-26 降级状态下处理数据的方法及独立冗余磁盘阵列系统 Expired - Fee Related CN101236482B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN2008101009332A CN101236482B (zh) 2008-02-26 2008-02-26 降级状态下处理数据的方法及独立冗余磁盘阵列系统

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN2008101009332A CN101236482B (zh) 2008-02-26 2008-02-26 降级状态下处理数据的方法及独立冗余磁盘阵列系统

Publications (2)

Publication Number Publication Date
CN101236482A true CN101236482A (zh) 2008-08-06
CN101236482B CN101236482B (zh) 2010-04-07

Family

ID=39920133

Family Applications (1)

Application Number Title Priority Date Filing Date
CN2008101009332A Expired - Fee Related CN101236482B (zh) 2008-02-26 2008-02-26 降级状态下处理数据的方法及独立冗余磁盘阵列系统

Country Status (1)

Country Link
CN (1) CN101236482B (zh)

Cited By (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102043593A (zh) * 2010-12-17 2011-05-04 天津曙光计算机产业有限公司 一种基于Region的磁盘外置cache管理方法
CN102147714A (zh) * 2011-03-17 2011-08-10 杭州宏杉科技有限公司 一种网络存储系统的管理方法及装置
CN102301339A (zh) * 2009-04-21 2011-12-28 国际商业机器公司 用于控制固态盘(ssd)设备的装置和方法
CN102411516A (zh) * 2011-12-13 2012-04-11 云海创想信息技术(天津)有限公司 一种raid5数据重建的方法及装置
CN102508747A (zh) * 2011-12-01 2012-06-20 浪潮电子信息产业股份有限公司 一种加快失效盘恢复的方法
CN103678025A (zh) * 2013-12-02 2014-03-26 创新科软件技术(深圳)有限公司 一种磁盘阵列中的磁盘故障处理方法
CN104035830A (zh) * 2014-06-24 2014-09-10 浙江宇视科技有限公司 一种数据恢复方法和装置
CN104166601A (zh) * 2014-08-14 2014-11-26 浙江宇视科技有限公司 一种存储数据的备份方法和装置
CN104484252A (zh) * 2014-12-26 2015-04-01 华为技术有限公司 固态硬盘的备电检测方法、装置和系统
CN104657237A (zh) * 2015-03-12 2015-05-27 浪潮集团有限公司 一种检测磁盘阵列的方法
CN104881242A (zh) * 2014-02-28 2015-09-02 中兴通讯股份有限公司 数据写入方法及装置
CN105359107A (zh) * 2013-05-16 2016-02-24 惠普发展公司,有限责任合伙企业 报告针对分布式对象取回的数据的降级状态
CN105528180A (zh) * 2015-12-03 2016-04-27 浙江宇视科技有限公司 一种数据存储方法、装置及设备
CN107122261A (zh) * 2017-04-18 2017-09-01 杭州宏杉科技股份有限公司 一种存储设备的数据读写方法及装置
CN108491162A (zh) * 2018-03-13 2018-09-04 山东超越数控电子股份有限公司 一种提高存储系统性能的方法及装置

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1253791C (zh) * 2002-11-22 2006-04-26 华为技术有限公司 5级独立冗余磁盘阵列中多盘失败情况下的读写操作方法

Cited By (25)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102301339A (zh) * 2009-04-21 2011-12-28 国际商业机器公司 用于控制固态盘(ssd)设备的装置和方法
CN102043593B (zh) * 2010-12-17 2013-03-13 曙光信息产业股份有限公司 一种基于Region的磁盘外置cache管理方法
CN102043593A (zh) * 2010-12-17 2011-05-04 天津曙光计算机产业有限公司 一种基于Region的磁盘外置cache管理方法
CN102147714B (zh) * 2011-03-17 2015-12-16 杭州宏杉科技有限公司 一种网络存储系统的管理方法及装置
CN102147714A (zh) * 2011-03-17 2011-08-10 杭州宏杉科技有限公司 一种网络存储系统的管理方法及装置
CN102508747A (zh) * 2011-12-01 2012-06-20 浪潮电子信息产业股份有限公司 一种加快失效盘恢复的方法
CN102411516A (zh) * 2011-12-13 2012-04-11 云海创想信息技术(天津)有限公司 一种raid5数据重建的方法及装置
US10296490B2 (en) 2013-05-16 2019-05-21 Hewlett-Packard Development Company, L.P. Reporting degraded state of data retrieved for distributed object
CN105359107B (zh) * 2013-05-16 2019-01-08 慧与发展有限责任合伙企业 报告针对分布式对象取回的数据的降级状态
CN105359107A (zh) * 2013-05-16 2016-02-24 惠普发展公司,有限责任合伙企业 报告针对分布式对象取回的数据的降级状态
CN103678025A (zh) * 2013-12-02 2014-03-26 创新科软件技术(深圳)有限公司 一种磁盘阵列中的磁盘故障处理方法
CN103678025B (zh) * 2013-12-02 2017-01-04 创新科软件技术(深圳)有限公司 一种磁盘阵列中的磁盘故障处理方法
CN104881242A (zh) * 2014-02-28 2015-09-02 中兴通讯股份有限公司 数据写入方法及装置
CN104035830B (zh) * 2014-06-24 2017-12-15 浙江宇视科技有限公司 一种数据恢复方法和装置
CN104035830A (zh) * 2014-06-24 2014-09-10 浙江宇视科技有限公司 一种数据恢复方法和装置
CN104166601A (zh) * 2014-08-14 2014-11-26 浙江宇视科技有限公司 一种存储数据的备份方法和装置
CN104166601B (zh) * 2014-08-14 2017-08-15 浙江宇视科技有限公司 一种存储数据的备份方法和装置
CN104484252A (zh) * 2014-12-26 2015-04-01 华为技术有限公司 固态硬盘的备电检测方法、装置和系统
CN104484252B (zh) * 2014-12-26 2017-11-24 华为技术有限公司 固态硬盘的备电检测方法、装置和系统
CN104657237A (zh) * 2015-03-12 2015-05-27 浪潮集团有限公司 一种检测磁盘阵列的方法
CN105528180A (zh) * 2015-12-03 2016-04-27 浙江宇视科技有限公司 一种数据存储方法、装置及设备
CN105528180B (zh) * 2015-12-03 2018-12-07 浙江宇视科技有限公司 一种数据存储方法、装置及设备
CN107122261A (zh) * 2017-04-18 2017-09-01 杭州宏杉科技股份有限公司 一种存储设备的数据读写方法及装置
CN107122261B (zh) * 2017-04-18 2020-04-07 杭州宏杉科技股份有限公司 一种存储设备的数据读写方法及装置
CN108491162A (zh) * 2018-03-13 2018-09-04 山东超越数控电子股份有限公司 一种提高存储系统性能的方法及装置

Also Published As

Publication number Publication date
CN101236482B (zh) 2010-04-07

Similar Documents

Publication Publication Date Title
CN101236482B (zh) 降级状态下处理数据的方法及独立冗余磁盘阵列系统
CN104794070B (zh) 基于动态非覆盖raid技术的固态闪存写缓存系统及方法
CN101566924B (zh) 一种磁盘阵列的数据读写方法
US9292228B2 (en) Selective raid protection for cache memory
US5634109A (en) Method and system for enhanced data management efficiency in memory subsystems utilizing redundant arrays of disk memory devices and a nonvolatile cache
KR100827677B1 (ko) 행렬 스트라이프 캐쉬를 이용한 raid 시스템의 입출력성능 향상 방법
US7133966B2 (en) Disk array device having spare disk drive and data sparing method
US20040128470A1 (en) Log-structured write cache for data storage devices and systems
US20070061514A1 (en) Disk array with spare logic drive created from spare physical drives
US20100306466A1 (en) Method for improving disk availability and disk array controller
CN107924291B (zh) 存储系统
CN106293990B (zh) 一种基于批量写校验的独立磁盘冗余阵列读写方法
CN100498678C (zh) 对廉价磁盘冗余阵列进行读写操作的方法和系统
US6378038B1 (en) Method and system for caching data using raid level selection
US20090327801A1 (en) Disk array system, disk controller, and method for performing rebuild process
CN101490662A (zh) 用于raid系统的磁盘缓存
CN102023809A (zh) 存储系统、从存储系统读取数据的方法及写入数据的方法
CN108958656B (zh) 基于raid5固态硬盘阵列的动态条带系统设计方法
US20050091452A1 (en) System and method for reducing data loss in disk arrays by establishing data redundancy on demand
CN104166601B (zh) 一种存储数据的备份方法和装置
CN101620517A (zh) 数据写入方法和装置
CN108255740A (zh) 一种flash均衡擦写方法及系统
US20040215877A1 (en) Methods and structure for rapid background initialization of a RAID logical unit
CN102799533A (zh) 一种磁盘损坏扇区屏蔽方法及装置
US20210318739A1 (en) Systems and methods for managing reduced power failure energy requirements on a solid state drive

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C14 Grant of patent or utility model
GR01 Patent grant
CP03 Change of name, title or address
CP03 Change of name, title or address

Address after: 310052 Binjiang District Changhe Road, Zhejiang, China, No. 466, No.

Patentee after: NEW H3C TECHNOLOGIES Co.,Ltd.

Address before: 310053 Hangzhou hi tech Industrial Development Zone, Zhejiang province science and Technology Industrial Park, No. 310 and No. six road, HUAWEI, Hangzhou production base

Patentee before: HANGZHOU H3C TECHNOLOGIES Co.,Ltd.

CF01 Termination of patent right due to non-payment of annual fee
CF01 Termination of patent right due to non-payment of annual fee

Granted publication date: 20100407