CN102884502B - 管理对在存储器件之间迁移的磁道延伸区的写入操作 - Google Patents
管理对在存储器件之间迁移的磁道延伸区的写入操作 Download PDFInfo
- Publication number
- CN102884502B CN102884502B CN201180022683.5A CN201180022683A CN102884502B CN 102884502 B CN102884502 B CN 102884502B CN 201180022683 A CN201180022683 A CN 201180022683A CN 102884502 B CN102884502 B CN 102884502B
- Authority
- CN
- China
- Prior art keywords
- memory
- previous version
- school affairs
- address
- effective
- 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.)
- Active
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0646—Horizontal data movement in storage systems, i.e. moving data in between storage devices or systems
- G06F3/065—Replication mechanisms
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0646—Horizontal data movement in storage systems, i.e. moving data in between storage devices or systems
- G06F3/0647—Migration mechanisms
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/0608—Saving storage space on storage systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/0604—Improving or facilitating administration, e.g. storage management
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/061—Improving I/O performance
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/0614—Improving the reliability of storage systems
- G06F3/0616—Improving the reliability of storage systems in relation to life time, e.g. increasing Mean Time Between Failures [MTBF]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0638—Organizing or formatting or addressing of data
- G06F3/064—Management of blocks
- G06F3/0641—De-duplication techniques
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0673—Single storage device
- G06F3/068—Hybrid storage device
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0683—Plurality of storage devices
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0683—Plurality of storage devices
- G06F3/0685—Hybrid storage combining heterogeneous device types, e.g. hierarchical storage, hybrid arrays
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Human Computer Interaction (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Techniques For Improving Reliability Of Storages (AREA)
Abstract
提供了一种用于管理对在存储器件之间迁移的磁道延伸区的写入操作的计算机程序产品、系统以及方法。处理将磁道延伸区从第二存储器迁移到第一存储器的操作。判定对于要迁移的延伸区是否存在延伸区对象。如果所述延伸区在先前时间预先被从所述第一存储器迁移到所述第二存储器,则所述延伸区对象存在。对于每个磁道,所述延伸区对象包括写入指示符,指示当所述延伸区被预先迁移到所述第二存储器时,自所述先前时间以来是否已在所述第二存储器中更新该磁道。响应于判定所述延伸区对象存在,确定所述延伸区中具有这样的写入指示符的磁道:所述写入指示符指示自所述先前时间以来已在所述第二存储器中更新该磁道。将所确定的磁道的数据从所述第二存储器复制到所述第一存储器中的空闲位置。对于每个所确定的磁道,在所述延伸区对象中更新所确定的磁道的表项,以将该磁道的数据被复制到的空闲位置指示为该磁道的有效地址。
Description
技术领域
本发明涉及一种用于管理对在存储器件之间迁移的磁道延伸区(extents oftracks)的写入操作的方法、系统以及计算机程序产品。
背景技术
在层级存储环境中,磁道延伸区可在诸如硬盘驱动器、固态存储器件之类的不同存储器件层之间迁移,这取决于存储器件的特征与存取频率和数据优先级。例如,较常存取的延伸区和/或较高优先级的延伸区可从较慢存取层迁移到较快存取层,而不常存取的延伸区和/或较低优先级的延伸区可迁移到较慢存取层。
在当前层级存储环境中,在给定时段内在上层/池和下层/池之间多次来回迁移延伸区。在此前提下,下层将升级给定延伸区,而不会认识到该延伸区在整体或部分上仍在上层中保持未被修改。当迁移延伸区时,可能将来自延伸区的所有数据从一个存储器件复制到另一个存储器件。此类迁移将花费大量时间。
在当前分层存储架构中,上层可包含从先前降级的延伸区到下层的旧的未修改(冗余)区(tracts),其可用作第二级缓存。当前解决方案的主要缺点是效率较低,因为固态存储器件(SSD)驱动器的读取性能显著高于硬盘驱动器的读取性能。
从已被停止供电的硬盘驱动器不必要地读取数据还会:
●缩短硬盘的寿命
●降低电源效率
●增加数据请求的存取时间,因为必须首先为驱动器供电
本领域中需要用于在存储器件之间迁移磁道延伸区并解决上述问题的改进的技术。
发明内容
提供了一种用于管理对在存储器件之间迁移的磁道延伸区的写入操作的计算机程序、计算机程序产品、系统以及方法。处理将磁道延伸区从第二存储器迁移到第一存储器的操作。判定对于要迁移的延伸区是否存在延伸区对象。如果所述延伸区在先前时间预先被从所述第一存储器迁移到所述第二存储器,则所述延伸区对象存在。对于每个磁道,所述延伸区对象包括写入指示符,指示当所述延伸区被预先迁移到所述第二存储器时,自所述先前时间以来是否已在所述第二存储器中更新该磁道。响应于判定所述延伸区对象存在,确定所述延伸区中具有这样的写入指示符的磁道:所述写入指示符指示自所述先前时间以来已在所述第二存储器中更新该磁道。将所确定的磁道的数据从所述第二存储器复制到所述第一存储器中的空闲位置。对于每个所确定的磁道,在所述延伸区对象中更新所确定的磁道的表项,以将该磁道的数据被复制到的空闲位置指示为该磁道的有效地址。
附图说明
现在将仅通过实例的方式参考附图中所示的优选实施例描述本发明,这些附图是:
图1示出根据现有技术并且其中可实现本发明的一个优选实施例的计算环境的一个实施例;
图2示出根据本发明的一个优选实施例的延伸区对象中的表项的一个实施例;
图3示出根据本发明的一个优选实施例的作为延伸区表的延伸区对象的一个实施例;
图4示出根据本发明的一个优选实施例的将延伸区从第二存储器迁移至第一存储器的操作的一个实施例;
图5示出根据本发明的一个优选实施例的用于处理对第一存储器中存在的延伸区中的磁道的写入请求的操作的一个实施例;
图6示出根据本发明的一个优选实施例的用于处理对第二存储器中存在的延伸区中的磁道的写入请求的操作的一个实施例。
具体实施方式
图1示出在第一存储器4与第二存储器6中存储数据磁道的服务器2的一个实施例。服务器2包括处理器8,处理器8包括一个或多个处理器器件与内存10,在内存10中,加载操作系统12以由处理器8执行。操作系统12包括延伸区迁移代码14,以管理在第一存储器4与第二存储器6之间由延伸区对象16所表示的磁道延伸区的迁移。磁道延伸区可以在第一存储器4或第二存储器6之一中是有效的,并可在第一存储器4与第二存储器6之间迁移。
服务器2可以以循环架构等,通过存储接口的单独电缆在网络上与第一存储器4和第二存储器6通信。第一存储器4与第二存储器6可包括不同类型的存储器件,诸如固态存储器件(SSD),其包含固态电子器件,诸如电可擦除可编程只读存储器(EEPROM)、闪存、快闪磁盘(FlashDisk)、随机存取内存(RAM)驱动器、存储级内存(SCM)等、磁性存储盘、光盘、磁带等。内存8可包括一个或多个易失性或非易失性内存器件。延伸区迁移代码14可以备选地实施为操作系统12外部的应用代码,或可以以硬件逻辑实施,诸如专用集成电路(ASIC)、或计算机可读存储介质中的可编程处理器执行代码。
在一个实施例中,第一存储器4与第二存储器6可包括存储器件层级配置内的存储层,其中层基于诸如输入/输出(I/O)存取规范(profile)速度、冗余之类的特征来定义存储器。例如,第一存储器4可包括高速存储器,诸如SSD或RAM驱动器,且第二存储器6可包括较慢存取存储器,诸如硬盘驱动器或磁带介质。采用本领域中公知的层级管理存储技术,操作系统12可调用延伸区迁移代码14,以将较不常被存取和/或具有较低优先级的延伸区从第一存储器4迁移至第二存储器6,并将较常被存取和/或较高优先级的磁道延伸区从第二存储器6迁移至第一存储器4。除了数据存取频率与数据优先级之外的数据特征可用来判定是否要在存储层级的较高与较低层存储器件之间迁移延伸区。
在特定实施例中,延伸区对象16标识在第二存储器6中连续存储的磁道,这在第二存储器6包括对于介质中连续存储磁道具有改进的读取/写入存取的存储器件(诸如硬盘驱动器与磁带驱动器)的实施例中是有利的。但是,延伸区中的磁道数据可能未连续存储在第一存储器内,所述第一存储器可包括未改进连续存储磁道存取的存储器件,诸如固态存储器件(SSD)或随机存取内存(RAM)驱动器。
延伸区对象16包括在一个延伸区内管理的每个磁道的表项。每个磁道可包括相同大小的单个数据单元。服务器2可在第一存储器4与第二存储器6中,维护服务器2管理的每个单独延伸区的多个延伸区对象16。另外,可存在额外的存储器件,使得服务器2可在两个以上存储器中管理磁道延伸区的迁移,其中不同存储器可具有不同I/O存取规范。
图2示出延伸区对象16中的表项50的一个实施例,所述表项提供有关延伸区中的一个磁道的信息。磁道标识符(ID)52标识延伸区中的磁道。修改指示符54指示当延伸区与磁道预先从第一存储器4迁移至第二存储器6时,自先前时间以来,是否已在第二存储器6中更新该磁道,因此指示当第二存储器6上存在磁道与延伸区时,第一存储器4是否具有磁道的最新版本。有效地址56指示第一存储器4中具有第二存储器6中的磁道的最新版本的地址。有效校验和58包括从有效地址56处的数据计算的校验和值。所述校验和值可利用本领域中公知的校验和或散列算法计算,以确定数据的独特或可能独特的表示。如果修改指示符52指示已在第二存储器6更新磁道且第一存储器4没有最新数据版本,则由于在第二存储器6处的更近的更新,有效地址56所标识的数据不包括有效版本,而是包括先前版本。
在特定实施例中,可将数据更新写入第一存储器4中的新的空闲位置。在此情况下,磁道的延伸区表项50可维护第一存储器4中存储的磁道的每个先前版本a...n的先前版本地址601....60n以及从磁道的先前版本计算的先前版本校验和621....62n。延伸区表80中的先前版本地址601...60n的顺序可指示先前版本的年龄,其中最新的先前版本地址是第一个,即601,最旧的先前版本地址为最后一个,即60n。服务器2可基于各种因素(诸如可用空间、预定的版本限制数、可用来存储先前版本的预定空间等)限制在第一存储器4中所维护的数据版本数。
在第一存储器4包括SSD的实施例中,当更新时常存取的逻辑地址时,作为称为写入平衡(Wear Leveling)的过程的一部分,将最近写入的数据写入到第一存储器4中的新的实际位置以跨存储器件分散写入,这将延长固态存储器件的寿命。持续写入到固态器件的同一物理位置会损耗固态存储器件中的存储块。
图3示出实现为延伸区表80的延伸区对象的一个实例,所述延伸区表对于每个磁道具有一个行,并且各列提供有关延伸区对象的信息。
图4示出在延伸区迁移代码14中实施的操作的一个实施例,此操作使延伸区从第二存储器6迁移或升级到第一存储器4。在处理迁移延伸区的请求(步骤100)后,判定(步骤102)要迁移磁道的延伸区的延伸区对象16是否存在。如果否,则延伸区迁移代码14进行步骤104,以创建延伸区的新延伸区对象16,并清除每个延伸区表项50(图2)的修改指示符54,以指示未在第二存储器2中修改数据。对于在延伸区16的每个磁道,延伸区迁移代码14对延伸区中每个磁道执行操作循环(步骤106-114)。对于每个磁道,将磁道从第二存储器6复制到第一存储器4中的空闲位置(步骤108)。延伸区迁移代码14计算(步骤110)所复制磁道的校验和,并将磁道的有效地址56设置(步骤112)成第一存储器4中该磁道被复制到的空闲位置;且将有效校验和58设置成所计算的校验和值。在初次将延伸区升级及迁移到第一存储器4时,执行步骤104-114的操作。
如果(步骤102)对于正在升级的延伸区,延伸区对象16已存在,则该延伸区预先被从第一存储器4迁移到第二存储器6,且在步骤116至128对延伸区中每个磁道执行循环,以从第二存储器6迁移或升级到第一存储器4。如果(步骤118)所考虑磁道的修改指示符54指示磁道未在第二存储器6中更新,则不对磁道执行任何操作且不会复制数据,因为数据并未改变。如果(步骤118)磁道的修改指示符54指示磁道已被修改,则将磁道的数据从第二存储器6复制(步骤120)到第一存储器4中的空闲位置。将磁道的新的先前版本地址设置成当前有效地址56,使磁道的当前数据成为先前版本,且将磁道的新的先前版本校验和设置成当前有效校验和58。然后,将有效地址56设置(步骤124)成数据被复制到的空闲位置的地址,且将有效校验和58设置(步骤126)成从复制到空闲位置的数据计算的校验和值。然后,先前版本对(先前版本地址601....60n与先前版本校验和62a....62n)被重新排序(步骤127),所以先前版本信息会按先前版本的年龄或版本号加以排序。
在延伸区对象16包括延伸区表80(图3)以执行步骤127的重新排序操作及产生当前有效数据与校验和先前版本的一个实施例中,延伸区迁移代码14可将当前的先前版本601....60n与62a....62n的列向右移两列,以覆写及占据先前版本2....n+l的列,然后将当前有效地址56与当前有效校验和58复制到最新当前先前版本地址601与621。如此,使当前版本地址56与校验和58成为最近先前版本,以在有效字段56与58内腾出空间给复制到空闲位置的已更新数据。在备选实施例中,排序以指示先前版本排序的指针或其他信息表示。
对于图4的操作,当延伸区从第二存储器6迁移或升级到第一存储器4时,自延伸区从第一存储器4迁移或降级到第二存储器6以来,只有已在第二存储器6中改变的磁道才被复制到第一存储器4。在第一存储器4包括SSD的实施例中,此描述的操作提供写入平衡,因为新数据被写入到新位置,且可避免对第一存储器4的非必要写入,因为自先前迁移以来,未在第二存储器6修改的数据不会被复制到第一存储器4。
图5示出由操作系统12执行的操作的一个实施例,其处理对第一存储器4中存在的延伸区中的磁道的写入。在接收写入后,操作系统12(或一些其他代码)从目标磁道的写入计算(步骤152)暂时校验和。如果(步骤154)暂时校验和匹配磁道的有效校验和58,则将完成返回给写入请求,因为在磁道有效地址56处的数据与要写入的数据相同。如此,数据不必被写入到第一存储器4,这在第一存储器包括寿命受到连续写入到相同位置的影响而减少的SSD或其他类型器件的实施例中,会降低写入平衡。如果(步骤154)暂时校验和值不匹配有效校验和58,则操作系统12判定(步骤158)暂时校验和值是否匹配先前版本校验和621....62n中的一个。可能存在零个或更多先前版本地址与校验和值。如果匹配,则操作系统12执行操作160-166,以使用在先前版本地址601....60n之一处的先前版本数据,因为先前版本数据匹配要写入的数据。在步骤160,操作系统12将新的先前版本地址与新的先前版本校验和值设置(步骤160)成有效地址与有效校验和值。此新的先前版本地址与新的先前版本校验和变成最新的先前版本地址601与校验和621。操作系统12将磁道的写入数据写入(步骤162)到第一存储器的空闲位置,并将有效地址56设置(步骤164)成数据被复制到的空闲位置的地址,并将有效校验和58设置(步骤166)成从空闲位置中的数据计算的校验和值。然后,先前版本对(先前版本地址601....60n与先前校验和62a....62n)被重新排序(步骤167),所以先前版本信息会按先前版本的年龄或版本号加以排序。
在延伸区对象16包括延伸区表80(图3)的实施例中,在创建新的先前版本地址与先前版本校验和以执行步骤167的重新排序操作之后,操作系统12可在所述表中将所有当前的先前版本地址601...60n与校验和621...62n向右移两列,以覆写列数据,并使其成为先前版本地址602...60n+1与校验和622...62n+1,然后所创建的新的先前版本地址与校验和变成先前版本地址601与校验和621。在备选实施例中,排序可藉由指示先前版本排序的指针或其他信息表示。
如果(步骤158)暂时校验和匹配一个所确定的先前版本校验和621....62n,则操作系统12缓冲(步骤168)匹配先前校验和的所确定的先前地址与先前校验和。操作系统12将新的先前版本地址与新的先前版本校验和设置(步骤170)成当前有效地址56与有效校验和58的值,以产生最新先前版本的当前有效地址与校验和。在执行步骤170之后,操作系统12接着分别将有效地址56与有效校验和58设置(步骤172)成所缓冲的先前版本地址与先前的版本校验和。在延伸区对象16包括延伸区表80(图3)的实施例中,在步骤168-172产生一个先前版本地址(例如,60i)、先前版本校验和(例如,62i)、当前有效版本56与58之后,操作系统12可接着在匹配的缓冲先前版本地址60i与校验和62i之后,在表80中将先前版本地址60i+1...60n与先前版本校验和62i+1...62n的所有列向左移两列,以覆写复制到有效字段56与58的匹配的缓冲先前版本地址60i与校验和62i所占据的列。
藉由图5所描述的实施例,操作系统12尝试使用当前有效地址56与58或一个先前版本地址60l...60n与新的有效地址56的校验和62l...62n与校验和58,以避免必须将数据写入到第一存储器4。如此,操作系统12针对新的写入数据,重复使用已在第一存储器4中存在的数据。在第一存储器4包括SSD的实施例中,使用写入的有效或先前版本数据以避免写入将避免磨损及延长SSD的寿命。
图6示出在操作系统12代码(或其他组件)中实施的操作的一个实施例,其处理对第二存储器6中存在的延伸区内的目标磁道的写入。当图6的操作开始时,延伸区对象16已建立。响应于(步骤200)接收到写入,操作系统12从目标磁道的写入计算(步骤202)暂时校验和。如果(步骤204)暂时校验和匹配磁道的有效校验和58且如果(步骤205)修改指示符54设置成指示第二存储器6内的磁道先前已修改,使得修改未在延伸区对象16中反映,则修改指示符54被清除(步骤206),因为第一存储器4磁道将具有在第二存储器6中修改的磁道。写入数据被写入(步骤208)到第二存储器中的磁道,且将完成返回(步骤210)给写入请求。在此情况下,因为在第一存储器4内的磁道的有效地址56处的数据与在第二存储器6写入的数据相同,所以延伸区对象16不必被更新。如果(步骤205)修改指示符54未设置,则控制会进行步骤210而不写入任何数据,因为在第一存储器4与第二存储器6两者内的有效或最近写入数据具有已匹配待写入数据的数据。
如果(步骤204)暂时校验和不匹配有效校验和58,则操作系统12判定(步骤212)暂时校验和是否匹配先前版本校验和62l....62n中的一个。可能存在零个或更多先前版本地址与校验和值。如果(步骤212)存在匹配,则操作系统12执行操作214-218,以使用在先前版本地址60l....60n中的一个处的先前版本磁道,因为在第一存储器6内的所确定的先前版本的磁道匹配写入到第二存储器6中的磁道的数据。操作系统12缓冲(步骤214)所确定的先前版本地址(例如,60i)、匹配的先前版本校验和62i的先前版本校验和(例如,62i)。操作系统12将新的先前版本地址与新的先前版本校验和设置(步骤216)成当前有效地址56与有效校验和58值。执行步骤216之后,操作系统12分别将有效地址56与有效校验和58设置(步骤218)成缓冲的先前版本地址60i与先前版本校验和62i。操作系统12清除(步骤206)修改指示符54以指示磁道未被修改,因为第一存储器4具有在第二存储器6处修改的数据。然后,控制进行步骤206至步骤208,以完成对第二存储器6的写入。
在延伸区对象16包括延伸区表80(图3)的实施例中,在步骤212-216产生一个先前版本地址(例如,60i)与先前版本校验和(例如,62i)、当前有效版本56与58之后,操作系统12可接着在匹配的缓冲先前版本地址60i与校验和62i之后,在表80中将先前版本地址60i+1与先前版本校验和62i+1的所有列向左移动两列,以覆写匹配的缓冲先前版本地址60i与校验和62i所占据的列。
如果(步骤212)暂时校验和不匹配一个先前版本校验和,则设置修改指示符42(步骤222),以指示数据已在第二存储器6中被修改,且控制进行到步骤208以完成到第二存储器6的写入。设置修改指示符54指示第一存储器6可能没有写入到第二存储器6的数据。在此情况下,在第一存储器6中,有效地址56处的数据不是“有效数据”,因为磁道数据已在第二存储器6中被修改,且在有效地址58处的磁道数据可能为最近先前版本。因此,当设置修改指示符54时,有效地址56与有效校验和56信息可能不能用于磁道的实际有效数据。
藉由图6所描述的实施例,如果第一存储器4中的磁道的先前存在数据匹配要写入到第二存储器6的数据,操作系统12将尝试使用当前有效地址56与58、或一个先前版本60l...60n与校验和62l...62n,作为在第一存储器4中的新有效地址56与有效校验和58。藉由更新延伸区对象16以反映第一存储器4具有写入到第二存储器6的数据,在将具有修改后的磁道的延伸区从第二存储器6迁移回第一存储器4时,不必随后使用写入到第二存储器6的磁道的数据来更新第一存储器4,因为修改指示符54被清除。在第一存储器4包括SSD的实施例中,使用第一存储器4内的有效或先前磁道版本用于到第二存储器6的写入,将避免在稍后从第二存储器6迁移到第一存储器4的过程内必须写入第一存储器。避免对第一存储器4的写入可减少磨损及延长SSD的寿命。
在图5与6的实施例中,在没有针对第一存储器4或第二存储器6中正在被写入的磁道维护的延伸区对象的情况下,允许写入进行而不执行任何进一步动作。另外,如果对于写入操作存在多个要写入的磁道,则针对每个要写入的磁道执行图5与6的操作。
当将延伸区从第二存储器迁移到第一存储器时、当执行对第一存储器中存在的延伸区的写入、以及当执行对第二存储器的写入时,所描述的实施例提供了用于减少写入第一存储器的次数的技术。在第一存储器包括SSD或其他存储器件(其存储寿命受到连续更新同一单元的影响而减少)的实施例中,所描述的实施例可减少磨损及延长存储器件的寿命。
其他实施例细节
所描述的操作可以以利用标准编程和/或工程技术的方法、装置或计算机程序产品实施,以产生软件、固件、硬件或其任何组合。因此,实施例的各方面可采用完全硬件实施例、完全软件实施例(包括固件、驻留软件、微码等)、或结合软件与硬体方面(所有在此通常称为“电路”、“模块”或“系统”)的实施例的形式。此外,实施例的各方面可采用在其中包含计算机可读程序代码的一个或多个计算机可读介质中体现的计算机程序产品的形式。
可以使用一个或多个计算机可读介质的任何组合。计算机可读介质可以是计算机可读信号介质或计算机可读存储介质,计算机可读存储介质例如可以是-但不限于-电的、磁的、光的、电磁的、红外线的、或半导体的系统、装置、器件、或前述各项的任何适当的组合。计算机可读存储介质的更具体的例子(非穷举的列表)包括以下:有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或前述各项的任何适当的组合。在本文语境中,计算机可读存储介质可以是任何含有或存储供指令执行系统、装置或器件使用的或与指令执行系统、装置或器件相联系的程序的有形介质。
计算机可读信号介质可以包括例如在基带中或作为载波的一部分传播的带有计算机可读程序代码的数据信号。这样一种传播信号可以采取任何适当的形式,包括-但不限于-电磁的、光的或其任何适当的组合。计算机可读信号介质可以是不同于计算机可读存储介质的、可以传达、传播或传输供指令执行系统、装置或器件使用的或与指令执行系统、装置或器件相联系的程序的任何一种计算机可读介质。
包含在计算机可读介质中的程序代码可以采用任何适当的介质传输,包括-但不限于-无线、有线、光缆、射频等等、或上述各项的任何适当的组合。
用于执行本发明的各方面的操作的计算机程序码,可以以一种或多种程序设计语言的任何组合来编写,所述程序设计语言包括面向对象的程序设计语言-诸如Java、Smalltalk、C++之类,还包括常规的过程式程序设计语言-诸如“C”程序设计语言或类似的程序设计语言。程序码可以完全地在用户的计算上执行、部分地在用户的计算机上执行、作为一个独立的软件包执行、部分在用户的计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在后一种情形中,远程计算机可以通过任何种类的网络-包括局域网(LAN)或广域网(WAN)-连接到用户的计算机,或者,可以(例如利用因特网服务提供商来通过因特网)连接到外部计算机。
以下参照按照本发明实施例的方法、装置(系统)和计算机程序产品的流程图和/或框图描述本发明的各方面。要明白的是,流程图和/或框图的每个方框以及流程图和/或框图中各方框的组合,都可以由计算机程序指令实现。这些计算机程序指令可以提供给通用计算机、专用计算机或其它可编程数据处理装置的处理器,从而生产出一种机器,使得通过计算机或其它可编程数据处理装置执行的这些指令,产生实现流程图和/或框图中的方框中规定的功能/操作的装置。
也可以将这些计算机程序指令存储在能指令计算机、其它可编程数据处理装置或其他设备以特定方式工作的计算机可读介质中,这样,存储在计算机可读介质中的指令产生一个包括实现流程图和/或框图中的方框中规定的功能/操作的指令装置的制品。
也可以将计算机程序指令加载到计算机、其它可编程数据处理装置或其他设备上,使得在所述计算机、其它可编程数据处理装置或其他设备上执行一系列操作步骤,以产生计算机实现的过程,从而在所述计算机或其它可编程装置上执行的指令就提供实现流程图和/或框图中的方框中规定的功能/操作的过程。
在特定实施例中,图1的服务器能以云计算环境中的云部件实施。在云计算环境中,在云计算递送中涉及的硬件与软件组件的系统架构可包括在网络(诸如因特网)上彼此通信的多个云组件。例如,在特定实施例中,图1的服务器可在网络云中提供客户端、其他服务器和软件和/或硬件组件以及存储和数据处理服务。服务器2可提供对存储器4与6的可靠存储服务与存取,以匹配云消费者的服务质量要求,包括需要存储的客户端及提供存储服务给客户端的其他服务器。服务器2可与客户端通信,以通过网络接口或其他应用编程接口提供存储器4与6的存储服务。
除非明确表示,否则术语“一个实施例”、“实施例”、“各实施例”、“该实施例”、“所述实施例”以及“一个或多个实施例”指“本发明的一个或多个(但不是全部)实施例”。
除非明确表示,否则术语“包括”、“包含”、“具有”及其变型指“包括但不限于”。
除非明确表示,否则列举的项目列表不暗示任何或所有项目是互斥的。
除非明确表示,否则术语“一”、“一个”与“该”指“一个或多个”。
除非在此特别指定,否则彼此通信的设备不必彼此连续通信。此外,彼此通信的设备可直接或通过一个或多个媒介物间接通信。
具有一些彼此通信的组件的实施例的描述不暗示需要所有此类组件。相反,描述多种可选组件来示意说明本发明的多种可能实施例。
此外,尽管可以按照连续的顺序来描述处理步骤、方法步骤、算法或类似步骤,但是此类处理、方法和算法可以被配置为以替代顺序工作。换句话说,所描述的步骤的任何序列或顺序并不一定指示要求按此顺序执行步骤。实际可以按任何顺序执行在此描述的处理的步骤。此外,可以同时执行某些步骤。
当在此描述单个设备或物品时,将显而易见的是,可以使用多个设备/物品(无论它们是否协作)来代替单个设备/物品。同样,当在此描述了多个设备或物品(无论它们是否协作)的情况下,将显而易见的是,可以使用单个设备或物品来代替多个设备或物品,或者可以使用不同数目的设备/物品代替所示数目的设备或程序。设备的功能和/或特性可以替代地由一个或多个其他未明确描述为具有此类功能/特性的设备来体现。因此,本发明的其他优选实施例不必包括设备本身。
图4-6的示意性操作显示以特定顺序发生的特定事件。在备选实施例中,特定操作能以不同的顺序执行、修改或移除。而且,可将步骤添加到上述逻辑,且仍然遵循描述的实施例。另外,在此描述的操作可连续发生或特定操作可被平行处理。此外,可由单个处理单元或分布式处理单元来执行操作。
出于例示与描述的目的,已提供本发明的各种优选实施例的上述描述。所述描述并非旨在是穷举的或是将本发明限于所公开的精确形式。鉴于以上教导,许多修改与变型是可能的。本发明的范围不受此详细描述的限制,而是由所附权利要求书限制。上述说明书、实例以及数据提供对本发明组成的制造与使用的完整描述。由于可在不偏离本发明的精神与范围的情况下实现本发明的许多实施例,所以本发明主张的权利在以下所附的权利要求书内。
Claims (17)
1.一种用于管理第一存储器与第二存储器中的数据的方法,所述方法包括以下步骤:
处理将磁道延伸区从所述第二存储器迁移到所述第一存储器的操作;
判定对于要迁移的延伸区是否存在延伸区对象,其中如果所述延伸区在先前时间预先被从所述第一存储器迁移到所述第二存储器,则所述延伸区对象存在,并且其中对于每个磁道,所述延伸区对象包括写入指示符,指示当所述延伸区被预先迁移到所述第二存储器时,自所述先前时间以来是否已在所述第二存储器中更新该磁道;及
响应于判定所述延伸区对象存在而执行以下步骤:
确定所述延伸区中具有这样的写入指示符的磁道:所述写入指示符指示自所述先前时间以来已在所述第二存储器中更新该磁道;
将所确定的磁道的数据从所述第二存储器复制到所述第一存储器中的空闲位置;及
对于每个所确定的磁道,在所述延伸区对象中更新所确定的磁道的表项,以将该磁道的数据被复制到的空闲位置指示为该磁道的有效地址。
2.如权利要求1的方法,其中所述延伸区对象维护所述第一存储器中的磁道数据的先前版本的信息,其中对于具有至少一个先前版本的每个磁道,该磁道的表项包括每个先前版本的先前版本地址,所述先前版本地址指示该磁道的该先前版本的数据在所述第一存储器中的位置,其中所述方法还包括以下步骤:
对于每个所确定的磁道,将新的先前版本地址设置成该磁道的有效地址,然后更新该有效地址以指示来自所述第二存储器的数据被复制到的空闲位置。
3.如权利要求1或2的方法,还包括:
提供包括固态存储器件的所述第一存储器;以及
提供包括具有慢于所述固态存储器件的输入/输出存取规范的存储器件类型的所述第二存储器。
4.如权利要求1或2的方法,其中所述第二存储器将磁道连续存储在所述延伸区中,并且其中所述方法还包括:将所述第二存储器中的已修改磁道复制到所述第一存储器中与所述延伸区内的未修改磁道有关的非相邻位置。
5.如权利要求1或2的方法,其中每个表项包括:从所述有效地址中标识的磁道数据计算的有效校验和值,并且所述有效校验和值用于在所述第一存储器中维护的磁道的至少一个先前版本;所述第一存储器中的磁道的先前版本的先前版本地址;以及从所述先前版本地址中标识的磁道数据计算的先前版本校验和值,其中所述方法还包括以下步骤:
接收对所述第一存储器中存在的延伸区中的目标磁道的写入;
从针对所述目标磁道的写入计算暂时校验和;
判定所述暂时校验和是否匹配所述有效校验和、或是否匹配所述目标磁道的延伸区对象中的表项内的至少一个先前版本校验和中的一个;
使用所述有效地址或所述先前版本地址以及对应有效或先前版本校验和,所述有效或先前版本校验和匹配所述有效地址的所述暂时校验和以及所述目标磁道的所述延伸区对象中的所述表项的有效校验和;及
响应于判定所述暂时校验和不匹配所述有效校验和或不匹配所述至少一个先前版本校验和中的任一个,将对所述目标磁道的写入操作写入到所述第一存储器中的空闲位置。
6.如权利要求5的方法,其中响应于判定所述暂时校验和匹配所述有效校验和或匹配所述至少一个先前版本校验和中的一个,对所述目标磁道的写入的写入步骤不写入所述第一存储器。
7.如权利要求5的方法,其中使用所述有效地址或所述先前版本地址以及匹配所述暂时校验和的对应校验和的步骤包括:
响应于判定所述暂时校验和匹配所述有效校验和或匹配所述至少一个先前版本校验和中的一个而返回写入完成;及
响应于判定所述暂时校验和匹配所述至少一个先前版本校验和中的一个,执行以下步骤:
针对匹配的先前版本校验和而缓冲所述先前版本地址与所述先前版本校验和;
将新的先前版本地址与新的先前版本校验和设置成所述有效地址与所述有效校验和的值;及
在设置所述新的先前版本地址与所述新的先前版本校验和之后,分别将所述有效地址与所述有效校验和设置成所缓冲的先前版本地址与所述先前版本校验和。
8.如权利要求1或2的方法,其中每个表项包括:从所述有效地址中标识的磁道数据计算的有效校验和值,并且所述有效校验和值用于在所述第一存储器中维护的磁道的至少一个先前版本;所述第一存储器中的磁道的先前版本的先前版本地址;以及从所述先前版本地址中标识的磁道数据计算的先前版本校验和值,其中所述方法还包括以下步骤:
接收对所述第二存储器中存在的延伸区中的目标磁道的写入;
从针对所述目标磁道的写入计算暂时校验和;
判定所述暂时校验和是否匹配所述有效校验和、或是否匹配所述目标磁道的延伸区对象中的表项内的至少一个先前版本校验和中的一个;
响应于判定匹配,使用所述有效地址或所述先前版本地址以及对应有效或先前版本校验和,所述有效或先前版本校验和匹配所述有效地址的所述暂时校验和以及所述目标磁道的所述延伸区对象中的所述表项的有效校验和。
9.如权利要求8的方法,所述方法还包括以下步骤:
设置所述延伸区对象中的目标磁道的所述表项内的所述指示符,以指示已响应于判定所述暂时校验和不匹配所述有效校验和或不匹配所述至少一个先前版本校验和中的一个而在所述第二存储器中更新该磁道,其中所述指示符指示所述第一存储器中的所述有效地址处的所述目标磁道的数据不是在所述第二存储器中维护的磁道数据的最新版本。
10.如权利要求8的方法,所述方法还包括以下步骤:
响应于判定所述暂时校验和匹配所述至少一个先前版本校验和中的一个,执行以下步骤:
针对匹配的先前版本校验和而缓冲所述先前版本地址与所述先前版本校验和;
将新的先前版本地址与新的先前版本校验和分别设置成所述有效地址与所述有效校验和的值;及
在设置所述新的先前版本地址与所述新的先前版本校验和之后,分别将所述有效地址与所述有效校验和设置成所缓冲的先前版本地址与所缓冲的先前版本校验和。
11.如权利要求1或2的方法,其中每个表项包括多个列,所述多个列包括:在有效校验和列中的有效校验和值,其从有效地址列中的有效地址内标识的磁道数据来计算,且用于在所述第一存储器中维护的磁道的至少一个先前版本;先前版本地址列,其具有所述第一存储器中的磁道的先前版本的地址;以及先前版本校验和列,其具有从所述先前版本地址处的磁道数据计算的校验和值,其中所述方法还包括以下步骤:
接收对所述第一存储器或所述第二存储器中存在的延伸区中的目标磁道的写入;
从针对所述目标磁道的写入计算暂时校验和;
判定所述暂时校验和是否匹配所述目标磁道的延伸区对象中的表项内的所述至少一个先前版本校验和中的一个;
将所述先前版本地址与匹配所述暂时校验和的对应先前版本校验和写入到所述目标磁道的延伸区对象中的所述表项的所述有效地址列与所述有效校验和列;及
移位版本早于所述先前版本地址的版本且校验和被写入到所述有效地址列与所述有效校验和列的任何先前地址列与先前校验和列,以覆写包括所述先前版本地址与写入到所述有效地址列与所述有效校验和列的对应先前版本校验和的所述先前地址列与所述先前校验和列。
12.一种与第一存储器及第二存储器通信的系统,所述系统包括:
处理器;
内存,其包括由所述处理器执行的代码以执行操作,所述系统包括:
处理部件,用于处理将磁道延伸区从所述第二存储器迁移到所述第一存储器的操作;
判定部件,用于判定对于要迁移的延伸区是否存在延伸区对象,其中如果所述延伸区在先前时间预先被从所述第一存储器迁移到所述第二存储器,则所述延伸区对象存在,并且其中对于每个磁道,所述延伸区对象包括写入指示符,指示当所述延伸区被预先迁移到所述第二存储器时,自所述先前时间以来是否已在所述第二存储器中更新该磁道;以及
响应于判定所述延伸区对象存在:
所述判定部件还可操作以确定所述延伸区中具有这样的写入指示符的磁道:所述写入指示符指示自所述先前时间以来已在所述第二存储器中更新该磁道;
复制部件,用于将所确定的磁道的数据从所述第二存储器复制到所述第一存储器中的空闲位置;以及
更新部件,对于每个所确定的磁道,所述更新部件用于在所述延伸区对象中更新所确定的磁道的表项,以将该磁道的数据被复制到的空闲位置指示为该磁道的有效地址。
13.如权利要求12的系统,其中所述延伸区对象维护所述第一存储器中的磁道数据的先前版本的信息,其中对于具有至少一个先前版本的每个磁道,该磁道的表项包括每个先前版本的先前版本地址,所述先前版本地址指示该磁道的该先前版本的数据在所述第一存储器中的位置,其中所述系统还包括:
设置部件,对于每个所确定的磁道,所述设置部件将新的先前版本地址设置成该磁道的有效地址,然后更新该有效地址以指示来自所述第二存储器的数据被复制到的空闲位置。
14.如权利要求12或13的系统,其中所述第一存储器包括固态存储器件,并且其中所述第二存储器包括具有慢于所述固态存储器件的输入/输出存取规范的存储器件类型。
15.如权利要求12或13的系统,其中每个表项包括:从所述有效地址中标识的磁道数据计算的有效校验和值,并且所述有效校验和值用于在所述第一存储器中维护的磁道的至少一个先前版本;所述第一存储器中的磁道的先前版本的先前版本地址;以及从所述先前版本地址中标识的磁道数据计算的先前版本校验和值,其中所述系统还包括:
接收部件,用于接收对所述第一存储器中存在的延伸区中的目标磁道的写入;
计算部件,用于从针对所述目标磁道的写入计算暂时校验和;
所述判定部件,其还可操作以判定所述暂时校验和是否匹配所述有效校验和、或是否匹配所述目标磁道的延伸区对象中的表项内的至少一个先前版本校验和中的一个;
使用部件,用于使用所述有效地址或所述先前版本地址以及对应有效或先前版本校验和,所述有效或先前版本校验和匹配所述有效地址的所述暂时校验和以及所述目标磁道的所述延伸区对象中的所述表项的有效校验和;以及
写入部件,用于响应于判定所述暂时校验和不匹配所述有效校验和或不匹配所述至少一个先前版本校验和中的任一个,将对所述目标磁道的写入操作写入到所述第一存储器中的空闲位置
16.如权利要求12或13的系统,其中每个表项包括:从所述有效地址中标识的磁道数据计算的有效校验和值,并且所述有效校验和值用于在所述第一存储器中维护的磁道的至少一个先前版本;所述第一存储器中的磁道的先前版本的先前版本地址;以及从所述先前版本地址中标识的磁道数据计算的先前版本校验和值,其中所述系统还包括:
接收部件,用于接收对所述第二存储器中存在的延伸区中的目标磁道的写入;
计算部件,用于从针对所述目标磁道的写入计算暂时校验和;
所述判定部件,其还可操作以判定所述暂时校验和是否匹配所述有效校验和、或是否匹配所述目标磁道的延伸区对象中的表项内的至少一个先前版本校验和中的一个;
使用部件,用于响应于判定匹配而使用所述有效地址或所述先前版本地址以及对应有效或先前版本校验和,所述有效或先前版本校验和匹配所述有效地址的所述暂时校验和以及所述目标磁道的所述延伸区对象中的所述表项的有效校验和。
17.如权利要求12或13的系统,其中每个表项包括多个列,所述多个列包括:在有效校验和列中的有效校验和值,其从有效地址列中的有效地址内标识的磁道数据来计算,且用于在所述第一存储器中维护的磁道的至少一个先前版本;先前版本地址列,其具有所述第一存储器中的磁道的先前版本的地址;以及先前版本校验和列,其具有从所述先前版本地址处的磁道数据计算的校验和值,其中所述系统还包括:
接收部件,用于接收对所述第一存储器或所述第二存储器中存在的延伸区中的目标磁道的写入;
计算部件,用于从针对所述目标磁道的写入计算暂时校验和;
判定部件,用于判定所述暂时校验和是否匹配所述目标磁道的延伸区对象中的表项内的所述至少一个先前版本校验和中的一个;
写入部件,用于将所述先前版本地址与匹配所述暂时校验和的对应先前版本校验和写入到所述目标磁道的延伸区对象中的所述表项的所述有效地址列与所述有效校验和列;及
移位部件,用于移位版本早于所述先前版本地址的版本且校验和被写入到所述有效地址列与所述有效校验和列的任何先前地址列与先前校验和列,以覆写包括所述先前版本地址与写入到所述有效地址列与所述有效校验和列的对应先前版本校验和的所述先前地址列与所述先前校验和列。
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/784,427 | 2010-05-20 | ||
US12/784,427 US8380949B2 (en) | 2010-05-20 | 2010-05-20 | Managing write operations to an extent of tracks migrated between storage devices |
PCT/EP2011/057398 WO2011144477A1 (en) | 2010-05-20 | 2011-05-09 | Managing write operations to an extent of tracks migrated between storage devices |
Publications (2)
Publication Number | Publication Date |
---|---|
CN102884502A CN102884502A (zh) | 2013-01-16 |
CN102884502B true CN102884502B (zh) | 2015-01-14 |
Family
ID=44169025
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201180022683.5A Active CN102884502B (zh) | 2010-05-20 | 2011-05-09 | 管理对在存储器件之间迁移的磁道延伸区的写入操作 |
Country Status (7)
Country | Link |
---|---|
US (3) | US8380949B2 (zh) |
JP (1) | JP5802263B2 (zh) |
CN (1) | CN102884502B (zh) |
DE (1) | DE112011100618B4 (zh) |
GB (1) | GB2493679B (zh) |
TW (1) | TW201211879A (zh) |
WO (1) | WO2011144477A1 (zh) |
Families Citing this family (27)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8671265B2 (en) | 2010-03-05 | 2014-03-11 | Solidfire, Inc. | Distributed data storage system providing de-duplication of data using block identifiers |
US8380949B2 (en) | 2010-05-20 | 2013-02-19 | International Business Machines Corporation | Managing write operations to an extent of tracks migrated between storage devices |
WO2012004837A1 (en) * | 2010-07-09 | 2012-01-12 | Hitachi, Ltd. | Storage apparatus and storage management method |
US9280550B1 (en) | 2010-12-31 | 2016-03-08 | Emc Corporation | Efficient storage tiering |
US8886901B1 (en) * | 2010-12-31 | 2014-11-11 | Emc Corporation | Policy based storage tiering |
US8868869B2 (en) | 2011-08-08 | 2014-10-21 | International Business Machines Corporation | Enhanced copy-on-write operation for solid state drives |
US9838269B2 (en) | 2011-12-27 | 2017-12-05 | Netapp, Inc. | Proportional quality of service based on client usage and system metrics |
US9054992B2 (en) | 2011-12-27 | 2015-06-09 | Solidfire, Inc. | Quality of service policy sets |
US9710397B2 (en) | 2012-02-16 | 2017-07-18 | Apple Inc. | Data migration for composite non-volatile storage device |
US10831728B2 (en) * | 2012-05-29 | 2020-11-10 | International Business Machines Corporation | Application-controlled sub-LUN level data migration |
US10831727B2 (en) * | 2012-05-29 | 2020-11-10 | International Business Machines Corporation | Application-controlled sub-LUN level data migration |
US10817202B2 (en) * | 2012-05-29 | 2020-10-27 | International Business Machines Corporation | Application-controlled sub-LUN level data migration |
US20150244795A1 (en) | 2014-02-21 | 2015-08-27 | Solidfire, Inc. | Data syncing in a distributed system |
WO2016102066A1 (en) * | 2014-12-22 | 2016-06-30 | Atotech Deutschland Gmbh | Method for electromagnetic shielding and thermal management of active components |
US10216966B2 (en) * | 2015-02-25 | 2019-02-26 | Netapp, Inc. | Perturb key technique |
US10929022B2 (en) | 2016-04-25 | 2021-02-23 | Netapp. Inc. | Space savings reporting for storage system supporting snapshot and clones |
US10248352B2 (en) | 2016-09-15 | 2019-04-02 | International Business Machines Corporation | Management of object location in hierarchical storage |
US10642763B2 (en) | 2016-09-20 | 2020-05-05 | Netapp, Inc. | Quality of service policy sets |
DE102017212181A1 (de) | 2017-07-17 | 2019-01-17 | Robert Bosch Gmbh | Verfahren und Vorrichtung zum Bestimmen von Prüfsummen, Pufferspeicher und Prozessor |
JP7007565B2 (ja) | 2017-11-20 | 2022-01-24 | 富士通株式会社 | 情報処理装置および情報処理プログラム |
US10684947B2 (en) * | 2018-04-20 | 2020-06-16 | International Business Machines Corporation | Increasing high performance data storage utilization by reducing write operations |
CN109271098B (zh) * | 2018-07-18 | 2021-03-23 | 成都华为技术有限公司 | 一种数据迁移方法及装置 |
US11100132B2 (en) * | 2018-10-11 | 2021-08-24 | International Business Machines Corporation | Intelligent space release in asynchronous mirror journal volumes |
US11614868B2 (en) * | 2019-09-30 | 2023-03-28 | International Business Machines Corporation | Data set overlay protection |
CN113467722B (zh) * | 2021-07-26 | 2024-04-30 | 浙江大华技术股份有限公司 | 一种分布式存储系统的数据迁移方法及装置 |
US11809731B2 (en) | 2021-09-28 | 2023-11-07 | International Business Machines Corporation | Appending data to a tape cartridge during recall operations |
CN115174771B (zh) * | 2022-06-23 | 2023-08-15 | 桂林医学院 | 一种儿童dr摄影辅助车及方法 |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP1679585A2 (en) * | 2005-01-10 | 2006-07-12 | Microsoft Corporation | System and methods for an overlay disk and cache using portable flash memory |
CN101410783A (zh) * | 2006-01-26 | 2009-04-15 | 网络装置公司 | 内容可寻址存储阵列元件 |
Family Cites Families (21)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5337275A (en) | 1992-10-30 | 1994-08-09 | Intel Corporation | Method for releasing space in flash EEPROM memory array to allow the storage of compressed data |
US5459850A (en) | 1993-02-19 | 1995-10-17 | Conner Peripherals, Inc. | Flash solid state drive that emulates a disk drive and stores variable length and fixed lenth data blocks |
US5720029A (en) * | 1995-07-25 | 1998-02-17 | International Business Machines Corporation | Asynchronously shadowing record updates in a remote copy session using track arrays |
JP3604466B2 (ja) | 1995-09-13 | 2004-12-22 | 株式会社ルネサステクノロジ | フラッシュディスクカード |
US6968350B2 (en) | 2001-04-07 | 2005-11-22 | Microsoft Corporation | Method for establishing a virtual hard drive for an emulated computer system running on a host computer system |
US7356641B2 (en) | 2001-08-28 | 2008-04-08 | International Business Machines Corporation | Data management in flash memory |
US9104315B2 (en) * | 2005-02-04 | 2015-08-11 | Sandisk Technologies Inc. | Systems and methods for a mass data storage system having a file-based interface to a host and a non-file-based interface to secondary storage |
JP2007066192A (ja) * | 2005-09-01 | 2007-03-15 | Hitachi Ltd | ストレージシステム及びその制御方法並びにコンピュータプログラム |
US8412682B2 (en) | 2006-06-29 | 2013-04-02 | Netapp, Inc. | System and method for retrieving and using block fingerprints for data deduplication |
US8315984B2 (en) * | 2007-05-22 | 2012-11-20 | Netapp, Inc. | System and method for on-the-fly elimination of redundant data |
US7669023B2 (en) * | 2007-07-10 | 2010-02-23 | Hitachi, Ltd. | Power efficient storage with data de-duplication |
US7694105B2 (en) | 2007-08-22 | 2010-04-06 | Hitachi Global Storage Technologies Netherlands, B.V. | Data storage systems that implement sector sets |
AU2008308549B9 (en) | 2007-10-05 | 2012-10-18 | Condusiv Technologies Corporation | Solid state drive optimizer |
US8880483B2 (en) | 2007-12-21 | 2014-11-04 | Sandisk Technologies Inc. | System and method for implementing extensions to intelligently manage resources of a mass storage system |
EP2263145B1 (en) * | 2008-02-12 | 2020-02-05 | NetApp, Inc. | Hybrid media storage system architecture |
KR101553532B1 (ko) * | 2008-04-17 | 2015-09-16 | 삼성전자주식회사 | 스토리지 장치 |
US8554983B2 (en) | 2008-05-27 | 2013-10-08 | Micron Technology, Inc. | Devices and methods for operating a solid state drive |
KR101517761B1 (ko) * | 2008-07-30 | 2015-05-06 | 시게이트 테크놀로지 엘엘씨 | 데이터 저장 위치 관리 방법 및 이를 데이터 저장 시스템 |
US8224782B2 (en) * | 2008-09-29 | 2012-07-17 | Hitachi, Ltd. | System and method for chunk based tiered storage volume migration |
JP2010102492A (ja) * | 2008-10-23 | 2010-05-06 | Hitachi Ltd | データアーカイブシステム |
US8380949B2 (en) | 2010-05-20 | 2013-02-19 | International Business Machines Corporation | Managing write operations to an extent of tracks migrated between storage devices |
-
2010
- 2010-05-20 US US12/784,427 patent/US8380949B2/en not_active Expired - Fee Related
-
2011
- 2011-05-09 JP JP2013510561A patent/JP5802263B2/ja active Active
- 2011-05-09 GB GB1221295.7A patent/GB2493679B/en active Active
- 2011-05-09 DE DE112011100618.7T patent/DE112011100618B4/de active Active
- 2011-05-09 WO PCT/EP2011/057398 patent/WO2011144477A1/en active Application Filing
- 2011-05-09 CN CN201180022683.5A patent/CN102884502B/zh active Active
- 2011-05-20 TW TW100117860A patent/TW201211879A/zh unknown
-
2012
- 2012-04-25 US US13/455,433 patent/US8656122B2/en not_active Expired - Fee Related
-
2014
- 2014-01-30 US US14/169,150 patent/US9218141B2/en active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP1679585A2 (en) * | 2005-01-10 | 2006-07-12 | Microsoft Corporation | System and methods for an overlay disk and cache using portable flash memory |
CN101410783A (zh) * | 2006-01-26 | 2009-04-15 | 网络装置公司 | 内容可寻址存储阵列元件 |
Also Published As
Publication number | Publication date |
---|---|
US20140149700A1 (en) | 2014-05-29 |
US8656122B2 (en) | 2014-02-18 |
JP5802263B2 (ja) | 2015-10-28 |
GB201221295D0 (en) | 2013-01-09 |
US8380949B2 (en) | 2013-02-19 |
TW201211879A (en) | 2012-03-16 |
DE112011100618T5 (de) | 2013-03-07 |
CN102884502A (zh) | 2013-01-16 |
US20110286123A1 (en) | 2011-11-24 |
JP2013533991A (ja) | 2013-08-29 |
GB2493679A (en) | 2013-02-13 |
DE112011100618B4 (de) | 2021-03-04 |
US20120272026A1 (en) | 2012-10-25 |
US9218141B2 (en) | 2015-12-22 |
WO2011144477A1 (en) | 2011-11-24 |
GB2493679B (en) | 2018-06-06 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN102884502B (zh) | 管理对在存储器件之间迁移的磁道延伸区的写入操作 | |
US6502108B1 (en) | Cache-failure-tolerant data storage system storing data objects with version code equipped metadata tokens | |
US7979641B2 (en) | Cache arrangement for improving raid I/O operations | |
CN102299904B (zh) | 一种实现业务数据备份的系统及方法 | |
CN101743546B (zh) | 用于提供快照的文件系统的分层存储管理 | |
CN104025010B (zh) | 存储系统中的可变长度编码 | |
CN100552612C (zh) | 闪速存储器存储系统 | |
CN102667772B (zh) | 文件级分级存储管理系统、方法和设备 | |
JP4900807B2 (ja) | ストレージシステム及びデータ管理方法 | |
JP5607059B2 (ja) | パーティション化した拡張可能で可用性の高い構造化ストレージにおけるパーティション管理 | |
US7660834B2 (en) | Maintaining an aggregate including active files in a storage pool | |
CN105359099A (zh) | 索引更新管线 | |
US20140325312A1 (en) | Method and system for scrubbing data within a data storage subsystem | |
CN105786408A (zh) | 闪存阵列中的逻辑扇区映射 | |
US20140075240A1 (en) | Storage apparatus, computer product, and storage control method | |
US20060077726A1 (en) | Data transfer method, storage apparatus and computer-readable storage medium | |
US20070239803A1 (en) | Remote mirroring method between tiered storage systems | |
CN101120305A (zh) | 新型即时复制操作 | |
CN102576293A (zh) | 固态存储设备和分层存储系统中的数据管理 | |
JP2005322237A (ja) | データ・ストレージ・システム間でのポイント・イン・タイム・コピー | |
JP2020154587A (ja) | 計算機システム及びデータ管理方法 | |
JP2007058286A (ja) | 記憶装置のフォーマットを不要としたストレージシステム及び記憶制御方法 | |
US20080301386A1 (en) | Remote copy system and remote copy control method | |
CN107341072A (zh) | 一种数据备份方法及装置 | |
CN1604046A (zh) | 用于管理关于目标卷与源卷之间关系的信息的方法和系统 |
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 |