CN110515549B - 一种数据迁移方法及装置 - Google Patents
一种数据迁移方法及装置 Download PDFInfo
- Publication number
- CN110515549B CN110515549B CN201910760741.2A CN201910760741A CN110515549B CN 110515549 B CN110515549 B CN 110515549B CN 201910760741 A CN201910760741 A CN 201910760741A CN 110515549 B CN110515549 B CN 110515549B
- Authority
- CN
- China
- Prior art keywords
- data
- preset
- ssd
- solid state
- read
- 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
- 238000013508 migration Methods 0.000 title claims abstract description 77
- 230000005012 migration Effects 0.000 title claims abstract description 77
- 238000000034 method Methods 0.000 title claims abstract description 62
- 239000007787 solid Substances 0.000 claims abstract description 93
- 230000008569 process Effects 0.000 description 12
- 230000009471 action Effects 0.000 description 3
- 238000012986 modification Methods 0.000 description 3
- 230000004048 modification Effects 0.000 description 3
- 238000005034 decoration Methods 0.000 description 2
- 238000010586 diagram Methods 0.000 description 2
- 238000005516 engineering process Methods 0.000 description 2
- 230000005055 memory storage Effects 0.000 description 2
- 238000012544 monitoring process Methods 0.000 description 2
- 238000011161 development Methods 0.000 description 1
- 238000004880 explosion Methods 0.000 description 1
- 230000006870 function Effects 0.000 description 1
- 238000005192 partition Methods 0.000 description 1
- 238000012545 processing Methods 0.000 description 1
- 230000000750 progressive effect Effects 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
Images
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/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/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/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0673—Single storage device
- G06F3/0679—Non-volatile semiconductor memory device, e.g. flash memory, one time programmable memory [OTP]
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)
- Techniques For Improving Reliability Of Storages (AREA)
- Signal Processing For Digital Recording And Reproducing (AREA)
Abstract
本发明提供一种数据迁移方法及装置,通过动态随机存取存储器DRAM将数据写入固态驱动器SSD,若在固态驱动器SSD中全部数据占用的存储容量大于或等于预设存储容量,将部分数据从固态驱动器SSD中迁移至硬盘驱动器HDD,在预设时间内,若被执行写操作的数据的次数大于预设写次数,则将数据迁移到非易失存储器NVM,或若被执行读操作的数据的次数大于预设读次数,则存储在固态驱动器SSD中的数据,不执行迁移操作。提高各个存储介质的利用率,解决了不能充分发挥各个存储介质的性能的问题。
Description
技术领域
本发明属于存储技术领域,具体为涉及一种数据迁移方法及装置。
背景技术
随着科学技术的进步,数据信息时代的到来,近几年来信息量快速发展,例如:各行各业都在疯狂的产生数据,海量数据的获取、挖掘及整合,源源不断的海量数据推进了信息爆炸的时代。因此,需要容量更大的存储介质和先进的存储技术,来解决当下的问题。例如:在传统存储的方法上,增加高速缓冲存储器。
但是,内存存储器和外存存储器频繁的交换数据,使得该内存存储器和外存存储器的使用寿命缩短,在后期会降低交换数据的速度,而且频繁更换存储器会产生较大的开销。
发明内容
有鉴于此,本发明的目的在于提供一种数据迁移方法及装置,用于提高各个存储介质的利用率,解决了不能充分发挥各个存储介质的性能的问题。技术方案如下:
本发明提供一种数据迁移方法,适用于存储系统,所述存储系统包括固态驱动器SSD、硬盘驱动器HDD、动态随机存取存储器DRAM和非易失存储器NVM,所述方法包括:
通过所述动态随机存取存储器DRAM将数据写入所述固态驱动器SSD;
若在所述固态驱动器SSD中全部数据占用的存储容量大于或等于预设存储容量,将部分数据从所述固态驱动器SSD中迁移至所述硬盘驱动器HDD;
在预设时间内,若被执行写操作的数据的次数大于预设写次数,则将所述数据迁移到所述非易失存储器NVM,或若被执行读操作的数据的次数大于预设读次数,则存储在所述固态驱动器SSD中的数据,不执行迁移操作。
优选的,所述方法还包括:
若数据被执行写操作的次数小于预设写次数,且被执行读操作的次数小于预设读次数,则将所述数据迁移至所述硬盘驱动器HDD。
优选的,通过所述动态随机存取存储器DRAM将数据写入所述固态驱动器SSD之后,还包括:
记录所述数据的热度值和所述数据的存储位置,其中,所述热度值为所述数据被执行读操作和写操作的频繁度,所述数据被执行读操作和写操作的频繁度越高,热度值越大。
优选的,所述若被执行写操作的数据的次数大于预设写次数,则将所述数据迁移到所述非易失存储器NVM之后,还包括:
若在当前预设时间内,存储在所述非易失存储器NVM中的数据被执行写操作的次数比前一预设时间内被执行写操作的次数少,则将所述数据迁移到所述固态驱动器SSD。
优选的,所述方法还包括:
若当前预设时间内,存储在所述固态驱动器SSD中的数据被执行读或写操作的次数比前一预设时间内的少,则将所述数据迁移到所述硬盘驱动器HDD。
本发明还提供一种数据迁移装置,适用于存储系统,所述存储系统包括固态驱动器SSD、硬盘驱动器HDD、动态随机存取存储器DRAM和非易失存储器NVM,所述装置包括:
写入模块,用于通过所述动态随机存取存储器DRAM将数据写入所述固态驱动器SSD;
第一迁移模块,用于若在所述固态驱动器SSD中全部数据占用的存储容量大于或等于预设存储容量,将部分数据从所述固态驱动器SSD中迁移至所述硬盘驱动器HDD;
第二迁移模块,用于在预设时间内,若被执行写操作的数据的次数大于预设写次数,则将所述数据迁移到所述非易失存储器NVM,或若被执行读操作的数据的次数大于预设读次数,则存储在所述固态驱动器SSD中的数据,不执行迁移操作。
优选的,所述装置还包括:
第三迁移模块,用于若数据被执行写操作的次数小于预设写次数,且被执行读操作的次数小于预设读次数,则将所述数据迁移至所述硬盘驱动器HDD。
优选的,所述装置还包括:
记录模块,用于记录所述数据的热度值和所述数据的存储位置,其中,所述热度值为所述数据被执行读操作和写操作的频繁度,所述数据被执行读操作和写操作的频繁度越高,热度值越大。
优选的,所述装置还包括:
第四迁移模块,用于若在当前预设时间内,存储在所述非易失存储器NVM中的数据被执行写操作的次数比前一预设时间内被执行写操作的次数少,则将所述数据迁移到所述固态驱动器SSD。
优选的,所述装置还包括:
第五迁移模块,用于若当前预设时间内,存储在所述固态驱动器SSD中的数据被执行读或写操作的次数比前一预设时间内的少,则将所述数据迁移到所述硬盘驱动器HDD。
与现有技术相比,本发明提供的上述技术方案具有如下优点:
通过动态随机存取存储器DRAM将数据写入固态驱动器SSD,若在固态驱动器SSD中全部数据占用的存储容量大于或等于预设存储容量,将部分数据从固态驱动器SSD中迁移至硬盘驱动器HDD,在预设时间内,若被执行写操作的数据的次数大于预设写次数,则将数据迁移到非易失存储器NVM,或若被执行读操作的数据的次数大于预设读次数,则存储在固态驱动器SSD中的数据,不执行迁移操作。提高各个存储介质的利用率,解决了不能充分发挥各个存储介质的性能的问题。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本发明实施例提供的一种数据迁移方法的流程图;
图2是本发明实施例提供的另一种数据迁移方法的流程图;
图3是本发明实施例提供的另一种数据迁移方法的流程图;
图4是本发明实施例提供的另一种数据迁移方法的流程图;
图5是本发明实施例提供的再另一种数据迁移方法的流程图;
图6是本发明实施例提供的一种数据迁移装置的结构示意图。
具体实施方式
本发明提供了一种数据迁移方法及装置,用于提高各个存储介质的利用率,解决了不能充分发挥各个存储介质的性能的问题。
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
如图1所示,示出了本发明实施例提供的一种数据迁移方法的流程图,该方法包括以下步骤:
S101:通过动态随机存取存储器DRAM将数据写入固态驱动器SSD。
在S101中,DRAM(Dynamic RandomAccess Memory,动态随机存取存储器),最为常见的系统内存。DRAM只能将数据保存很短的时间。为了保存数据,DRAM使用电容存储,所以必须隔一段时间刷新(refresh)一次,如果存储单元没有被刷新,存储的信息就会丢失。例如:在计算机进行关机时,电源断开就会丢失数据。
固态驱动器(Solid State Disk或Solid State Drive,SSD),俗称固态硬盘,固态硬盘是用固态电子存储芯片阵列而制成的硬盘。SSD由控制单元和存储单元(FLASH芯片、DRAM芯片)组成。固态硬盘在接口的规范和定义、功能及使用方法上与普通硬盘的完全相同,在产品外形和尺寸上也完全与普通硬盘一致。被广泛应用于军事、车载、工控、视频监控、网络监控、网络终端、电力、医疗、航空、导航设备等诸多领域。
在执行S101的过程中,当数据被执行写操作时,系统通过DRAM将数据写入到SSD中。即将系统中的数据保存到硬盘中,进行存储。
例如:在计算机中,存储系统可分内存和外存,硬盘就是外存,所有的数据都存储在硬盘上。计算机计算数据时,中央处理器CPU命令将硬盘中的数据读入内存,好提供给自己处理计算,然后获得结果发送给内存,通过内存将数据再写到硬盘中。需要说明的是,硬盘是机械磁存储读写速度太慢,不能匹配CPU处理数据速度,而内存是电存储,它可以匹配CPU,相当于一个中转,内存提前读入硬盘中的数据,再供给CPU使用。
需要说明的是,包括但不限于通过DRAM将数据写入至固态驱动器SSD,可根据实际情况选择硬盘,对数据进行存储。
S102:判断固态驱动器SSD中全部数据占用的存储容量是否大于或等于预设存储容量,若是,执行S103,若否,执行S104。
在执行S102的过程中,系统一直监控着固态驱动器SSD的存储状态,该存储状态指的是数据在该SSD中,占用的存储容量。为了保护固态驱动器SSD,减少该固态驱动器SSD的使用损耗,因此设置一个预设存储容量,用来监控固态驱动器SSD的存储状态,当监控到固态驱动器SSD已使用的存储容量大于或等于预设存储容量,则执行相应的操作,缓解固态驱动器SSD的存储压力。
例如:固态驱动器SSD的存储容量为100GB,当该固态驱动器SSD用来存储数据的容量达到70GB的时候,则不能在用来存储数据了,需要将部分数据迁移出来。
需要说明的是,用来监控固态驱动器SSD的预设存储容量,可根据实际情况进行设定,这里不再进行赘述。
S103:将部分数据从固态驱动器SSD中迁移至硬盘驱动器HDD。
在S103中,HDD(Hard Disk Drive,硬盘驱动器),是最基本的电脑存储器。例如:电脑硬盘C盘、D盘等磁盘分区都属于硬盘驱动器。目前硬盘一般常见的磁盘容量为80G、128G、160G、256G、320G、500G、750G、1TB和2TB等等。硬盘按体积大小可分为3.5寸、2.5寸、1.8寸等;按转数可分为5400rpm/7200rpm/10000rpm等;按接口可分为PATA、SATA、SCSI等。PATA、SATA一般为桌面级应用,容量大,价格相对较低,适合家用;而SCSI一般为服务器、工作站等高端应用,容量相对较小,价格较贵,但是性能较好,稳定性也较高。
在执行S103的过程中,因为固态驱动器SSD的存储容量有限,如果写入数据的总容量达到固态驱动器SSD的预设存储容量,那么需要将该固态驱动器SSD中的部分数据迁移到硬盘驱动器HDD中,直到固态驱动器SSD中的数据占用的容量小于预设存储容量。
例如:如果固态驱动器SSD存储容量为100GB,数据在固态驱动器SSD中的占用存储容量大于70%,即70GB,则需要将部分数据迁移到硬盘驱动器HDD中,如可将20GB的数据迁移至硬盘驱动器HDD中,这样使得固态驱动器SSD中数据的占用存储容量减少到50GB,大大缓解了固态驱动器SSD的存储压力。
需要说明的是,可按照固态驱动器SSD中被执行读、写次数较少的数据,按顺序将这些数据从固态驱动器SSD迁移至硬盘驱动器HDD。
S104:不执行迁移操作。
在执行S104的过程中,如果固态驱动器SSD中数据的占用容量,未达到预设存储容量,那么不执行迁移操作,继续将数据写入到固态驱动器SSD。
S105:在预设时间内,判断被执行写操作和读操作的数据的次数是否大于预设写次数和预设读次数,若被执行写操作的数据的次数大于预设写次数,则执行S106,若被执行读操作的次数大于预设读次数,则执行S104。
在执行S105的过程中,设置一个预设时间段、预设写次数和预设读次数。在该预设时间段内,对每个数据的写操作和读操作进行记录,然后判断被执行写操作的数据是否大于预设写次数,如果大于,说明该数据经常使用,需将该数据存储在一个数据不易丢失的存储器中。
S106:将数据迁移到非易失存储器NVM。
在S106中,NVM(Non-volatile memory,非易失存储器)具有非易失、按字节存取、存储密度高、低能耗、读写性能接近DRAM,但读写速度不对称。当电流关掉后,所存储的数据不会消失的一种计算机存储器。
在执行S106的过程中,在预设时间段内,若数据被执行写操作的次数大于预设写次数,则将该数据迁移至非易失存储器NVM中。
例如,在一个小时内,一种数据被执行写操作的次数为8,而预设写次数为6,那么该数据就需要迁移至非易失存储器NVM中。
需要说明的是,预设时间和预设写次数可根据实际情况进行设定,这里不再进行赘述。
根据上述本发明实施例公开的数据迁移方法可知,通过动态随机存取存储器DRAM将数据写入固态驱动器SSD,若在固态驱动器SSD中全部数据占用的存储容量大于或等于预设存储容量,将部分数据从固态驱动器SSD中迁移至硬盘驱动器HDD,在预设时间内,若被执行写操作的数据的次数大于预设写次数,则将数据迁移到非易失存储器NVM,或若被执行读操作的数据的次数大于预设读次数,则存储在固态驱动器SSD中的数据,不执行迁移操作。提高各个存储介质的利用率,解决了不能充分发挥各个存储介质的性能的问题。
基于上述本发明实施例公开的数据迁移方法,如图2所示,为本发明实施例提供的另一种数据迁移方法的流程图,主要包括:
S201:通过动态随机存取存储器DRAM将数据写入固态驱动器SSD。
S202:判断固态驱动器SSD中全部数据占用的存储容量是否大于或等于预设存储容量,若是,执行S203,若否,执行S204。
S203:将部分数据从固态驱动器SSD中迁移至硬盘驱动器HDD。
S204:不执行迁移操作。
S201至S204的执行原理和上述S101至S104的一致,这里不再进行赘述。
S205:在预设时间内,判断被执行写操作和读操作的数据的次数是否大于预设写次数和预设读次数,若数据被执行写操作的次数小于预设写次数,且被执行读操作的次数小于预设读次数,则执行S206。
S206:将数据迁移至硬盘驱动器HDD。
在执行S206的过程中,如果在预设时间内,数据被执行写操作的次数小于预设写次数且被执行读操作的次数小于预设读次数,则将数据从SDD迁移至硬盘驱动器HDD中。
例如:在一个小时内,数据被执行写操作为3次,读次数为0次,而预设写次数为8次,预设读次数为1次,该数据被执行写次数和被执行读次数都小于预设写次数和预设读次数,所以需要将该数据从SDD中迁移至硬盘驱动器HDD。
根据上述本发明实施例公开的数据迁移方法可知,通过动态随机存取存储器DRAM将数据写入固态驱动器SSD,若在固态驱动器SSD中全部数据占用的存储容量大于或等于预设存储容量,将部分数据从固态驱动器SSD中迁移至硬盘驱动器HDD,在预设时间内,若被执行写操作的数据的次数大于预设写次数,则将数据迁移到非易失存储器NVM,或若被执行读操作的数据的次数大于预设读次数,则存储在固态驱动器SSD中的数据,不执行迁移操作。提高各个存储介质的利用率,解决了不能充分发挥各个存储介质的性能的问题。
基于上述本发明实施例公开的数据迁移方法,如图3所示,为本发明实施例提供的另一种数据迁移方法的流程图,该方法包括以下步骤:
S301:通过动态随机存取存储器DRAM将数据写入固态驱动器SSD。
S301的执行原理和上述S101的一致,这里不再进行赘述。
S302:记录数据的热度值和数据的存储位置。
在S302中,数据的热度值指的是数据被执行读操作和写操作的频繁度,即数据被执行读操作和写操作的频繁度越高,热度值越大。
存储位置指的是:被写入的数据存储在哪个存储器中。
在执行S302的过程中,对写入固态驱动器SSD的数据,进行热度值的记录以及存储位置的记录,通过记录的方式,能够清楚的了解数据的各方面的信息。
需要说明的是,因为在本发明实施例中,存在多个存储介质,所以需要将这些存储介质分为一级存储介质、二级存储介质依次类推。所以除了记录上述数据热度值和存储位置外,还需要标记存储在了第几级存储介质中。
根据上述本发明实施例公开的数据迁移方法可知,通过动态随机存取存储器DRAM将数据写入固态驱动器SSD,然后记录数据的热度值和数据的存储位置,能够清楚的了解数据的各方面的信息。
基于上述本发明实施例公开的数据迁移方法,如图4所示,为本发明实施例提供的另一种数据迁移方法的流程图,该方法包括以下步骤:
S401:判断当前预设时间内,存储在非易失存储器NVM中的数据被执行写操作的次数是否比前一预设时间内被执行写操作的次数少,若是,执行S402,若否,执行S403。
S402:将数据迁移到固态驱动器SSD。
S403:不进行迁移操作。
根据上述本发明实施例公开的数据迁移方法可知,通过动态随机存取存储器DRAM将数据写入固态驱动器SSD,若在固态驱动器SSD中全部数据占用的存储容量大于或等于预设存储容量,将部分数据从固态驱动器SSD中迁移至硬盘驱动器HDD,在预设时间内,若被执行写操作的数据的次数大于预设写次数,则将数据迁移到非易失存储器NVM,或若被执行读操作的数据的次数大于预设读次数,则存储在固态驱动器SSD中的数据,不执行迁移操作。提高各个存储介质的利用率,解决了不能充分发挥各个存储介质的性能的问题。
基于上述本发明实施例公开的数据迁移方法,如图5所示,为本发明实施例提供的再另一种数据迁移方法的流程图,该方法包括以下步骤:
S501:判断当前预设时间内,存储在非易失存储器NVM中的数据被执行写操作的次数是否比前一预设时间内被执行写操作的次数少,若是,执行S502,若否,执行S503。
S502:将数据迁移到固态驱动器SSD。
S503:不进行迁移操作。
S501至S503的执行原理和上述S401至S402的一致,这里不再进行赘述。
S504:判断当前预设时间内,存储在固态驱动器SSD中的数据被执行读或写操作的次数是否比前一预设时间内被执行读操作或写操作的次数少,若是,执行S505,若否,执行S503。
S505:将数据迁移到硬盘驱动器HDD。
根据上述本发明实施例公开的数据迁移方法可知,通过动态随机存取存储器DRAM将数据写入固态驱动器SSD,若在固态驱动器SSD中全部数据占用的存储容量大于或等于预设存储容量,将部分数据从固态驱动器SSD中迁移至硬盘驱动器HDD,在预设时间内,若被执行写操作的数据的次数大于预设写次数,则将数据迁移到非易失存储器NVM,或若被执行读操作的数据的次数大于预设读次数,则存储在固态驱动器SSD中的数据,不执行迁移操作。提高各个存储介质的利用率,解决了不能充分发挥各个存储介质的性能的问题。
基于上述本发明实施例公开的数据迁移方法,本发明实施例还相应的公开一种数据迁移装置,如图6所示,为本发明实施例提供的一种数据迁移装置的结构示意图,主要包括:写入模块60、第一迁移模块61和第二迁移模块62。
写入模块60,用于通过动态随机存取存储器DRAM将数据写入固态驱动器SSD。
第一迁移模块61,用于若在固态驱动器SSD中全部数据占用的存储容量大于或等于预设存储容量,将部分数据从固态驱动器SSD中迁移至硬盘驱动器HDD。
第二迁移模块62,用于在预设时间内,若被执行写操作的数据的次数大于预设写次数,则将数据迁移到非易失存储器NVM,或若被执行读操作的数据的次数大于预设读次数,则存储在固态驱动器SSD中的数据,不执行迁移操作。
根据上述本发明实施例公开的数据迁移装置可知,通过动态随机存取存储器DRAM将数据写入固态驱动器SSD,若在固态驱动器SSD中全部数据占用的存储容量大于或等于预设存储容量,将部分数据从固态驱动器SSD中迁移至硬盘驱动器HDD,在预设时间内,若被执行写操作的数据的次数大于预设写次数,则将数据迁移到非易失存储器NVM,或若被执行读操作的数据的次数大于预设读次数,则存储在固态驱动器SSD中的数据,不执行迁移操作。提高各个存储介质的利用率,解决了不能充分发挥各个存储介质的性能的问题。
基于上述本发明装置实施例公开的数据迁移装置,该数据迁移装置还包括:第三迁移模块。
第三迁移模块,用于若数据被执行写操作的次数小于预设写次数,且被执行读操作的次数小于预设读次数,则将数据迁移至硬盘驱动器HDD。
基于上述本发明装置实施例公开的数据迁移装置,该数据迁移装置还包括:记录模块。
记录模块,用于记录数据的热度值和数据的存储位置,其中,热度值为数据被执行读操作和写操作的频繁度,即数据被执行读操作和写操作的频繁度越高,热度值越大。
根据上述本发明实施例公开的数据迁移装置可知,通过动态随机存取存储器DRAM将数据写入固态驱动器SSD,然后记录数据的热度值和数据的存储位置,能够清楚的了解数据的各方面的信息。
基于上述本发明装置实施例公开的数据迁移装置,该数据迁移装置还包括:第四迁移模块。
第四迁移模块,用于若在当前预设时间内,存储在非易失存储器NVM中的数据被执行写操作的次数比前一预设时间内被执行写操作的次数少,则将数据迁移到固态驱动器SSD。
基于上述本发明装置实施例公开的数据迁移装置,该数据迁移装置还包括:第五迁移模块。
第五迁移模块,用于若当前预设时间内,存储在固态驱动器SSD中的数据被执行读或写操作的次数比前一预设时间内的少,则将数据迁移到硬盘驱动器HDD。
根据上述本发明实施例公开的数据迁移装置可知,通过动态随机存取存储器DRAM将数据写入固态驱动器SSD,若在固态驱动器SSD中全部数据占用的存储容量大于或等于预设存储容量,将部分数据从固态驱动器SSD中迁移至硬盘驱动器HDD,在预设时间内,若被执行写操作的数据的次数大于预设写次数,则将数据迁移到非易失存储器NVM,或若被执行读操作的数据的次数大于预设读次数,则存储在固态驱动器SSD中的数据,不执行迁移操作。提高各个存储介质的利用率,解决了不能充分发挥各个存储介质的性能的问题。
需要说明的是,本说明书中的各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似的部分互相参见即可。对于装置类实施例而言,由于其与方法实施例基本相似,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
对所公开的实施例的上述说明,使本领域技术人员能够实现或使用本发明。对这些实施例的多种修改对本领域技术人员来说将是显而易见的,本文中所定义的一般原理可以在不脱离本发明的精神或范围的情况下,在其它实施例中实现。因此,本发明将不会被限制于本文所示的这些实施例,而是要符合与本文所公开的原理和新颖特点相一致的最宽的范围。
以上所述仅是本发明的优选实施方式,应当指出,对于本技术领域的普通技术人员来说,在不脱离本发明原理的前提下,还可以做出若干改进和润饰,这些改进和润饰也应视为本发明的保护范围。
Claims (10)
1.一种数据迁移方法,适用于存储系统,所述存储系统包括固态驱动器SSD、硬盘驱动器HDD、动态随机存取存储器DRAM和非易失存储器NVM,所述方法包括:
通过所述动态随机存取存储器DRAM将数据写入所述固态驱动器SSD;
若在所述固态驱动器SSD中全部数据占用的存储容量大于或等于预设存储容量,将部分数据从所述固态驱动器SSD中迁移至所述硬盘驱动器HDD;
在预设时间内,判断被执行写操作和读操作的数据的次数是否大于预设写次数和预设读次数;
若被执行写操作的数据的次数大于预设写次数,则将所述数据迁移到所述非易失存储器NVM;
若被执行读操作的数据的次数大于预设读次数,则存储在所述固态驱动器SSD中的数据,不执行迁移操作。
2.根据权利要求1所述的方法,其特征在于,所述方法还包括:
若数据被执行写操作的次数小于预设写次数,且被执行读操作的次数小于预设读次数,则将所述数据迁移至所述硬盘驱动器HDD。
3.根据权利要求1所述的方法,其特征在于,通过所述动态随机存取存储器DRAM将数据写入所述固态驱动器SSD之后,还包括:
记录所述数据的热度值和所述数据的存储位置,其中,所述热度值为所述数据被执行读操作和写操作的频繁度,所述数据被执行读操作和写操作的频繁度越高,热度值越大。
4.根据权利要求1所述的方法,其特征在于,所述若被执行写操作的数据的次数大于预设写次数,则将所述数据迁移到所述非易失存储器NVM之后,还包括:
若在当前预设时间内,存储在所述非易失存储器NVM中的数据被执行写操作的次数比前一预设时间内被执行写操作的次数少,则将所述数据迁移到所述固态驱动器SSD。
5.根据权利要求4所述的方法,其特征在于,所述方法还包括:
若当前预设时间内,存储在所述固态驱动器SSD中的数据被执行读或写操作的次数比前一预设时间内的少,则将所述数据迁移到所述硬盘驱动器HDD。
6.一种数据迁移装置,适用于存储系统,所述存储系统包括固态驱动器SSD、硬盘驱动器HDD、动态随机存取存储器DRAM和非易失存储器NVM,所述装置包括:
写入模块,用于通过所述动态随机存取存储器DRAM将数据写入所述固态驱动器SSD;
第一迁移模块,用于若在所述固态驱动器SSD中全部数据占用的存储容量大于或等于预设存储容量,将部分数据从所述固态驱动器SSD中迁移至所述硬盘驱动器HDD;
第二迁移模块,用于在预设时间内,判断被执行写操作和读操作的数据的次数是否大于预设写次数和预设读次数,若被执行写操作的数据的次数大于预设写次数,则将所述数据迁移到所述非易失存储器NVM,若被执行读操作的数据的次数大于预设读次数,则存储在所述固态驱动器SSD中的数据,不执行迁移操作。
7.根据权利要求6所述的装置,其特征在于,所述装置还包括:
第三迁移模块,用于若数据被执行写操作的次数小于预设写次数,且被执行读操作的次数小于预设读次数,则将所述数据迁移至所述硬盘驱动器HDD。
8.根据权利要求6所述的装置,其特征在于,所述装置还包括:
记录模块,用于记录所述数据的热度值和所述数据的存储位置,其中,所述热度值为所述数据被执行读操作和写操作的频繁度,所述数据被执行读操作和写操作的频繁度越高,热度值越大。
9.根据权利要求6所述的装置,其特征在于,所述装置还包括:
第四迁移模块,用于若在当前预设时间内,存储在所述非易失存储器NVM中的数据被执行写操作的次数比前一预设时间内被执行写操作的次数少,则将所述数据迁移到所述固态驱动器SSD。
10.根据权利要求6所述的装置,其特征在于,所述装置还包括:
第五迁移模块,用于若当前预设时间内,存储在所述固态驱动器SSD中的数据被执行读或写操作的次数比前一预设时间内的少,则将所述数据迁移到所述硬盘驱动器HDD。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910760741.2A CN110515549B (zh) | 2019-08-16 | 2019-08-16 | 一种数据迁移方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910760741.2A CN110515549B (zh) | 2019-08-16 | 2019-08-16 | 一种数据迁移方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN110515549A CN110515549A (zh) | 2019-11-29 |
CN110515549B true CN110515549B (zh) | 2022-03-22 |
Family
ID=68626449
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910760741.2A Active CN110515549B (zh) | 2019-08-16 | 2019-08-16 | 一种数据迁移方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110515549B (zh) |
Families Citing this family (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111208940A (zh) * | 2019-12-24 | 2020-05-29 | 华东师范大学 | 一种基于多通道闪存的读写分离方法 |
CN114816216A (zh) * | 2021-01-19 | 2022-07-29 | 华为技术有限公司 | 一种容量调整的方法以及相关装置 |
CN113238647A (zh) * | 2021-05-31 | 2021-08-10 | 山东中科好靓科技有限公司 | 一种用于存储的节能分时控制方法 |
CN115543221B (zh) * | 2022-11-29 | 2023-03-14 | 苏州浪潮智能科技有限公司 | 固态硬盘的数据迁移方法、装置、电子设备及存储介质 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN105808156A (zh) * | 2014-12-31 | 2016-07-27 | 华为技术有限公司 | 将数据写入固态硬盘的方法及固态硬盘 |
CN106326135A (zh) * | 2015-06-30 | 2017-01-11 | 华为技术有限公司 | 一种平移非易失性存储器nvm的数据的方法及装置 |
CN109375880A (zh) * | 2018-11-05 | 2019-02-22 | 郑州云海信息技术有限公司 | 一种数据均衡方法、装置和计算机可读存储介质 |
Family Cites Families (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP6476959B2 (ja) * | 2015-02-13 | 2019-03-06 | 富士通株式会社 | ストレージ制御装置、ストレージシステム、および制御プログラム |
CN105786717B (zh) * | 2016-03-22 | 2018-11-16 | 华中科技大学 | 软硬件协同管理的dram-nvm层次化异构内存访问方法及系统 |
-
2019
- 2019-08-16 CN CN201910760741.2A patent/CN110515549B/zh active Active
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN105808156A (zh) * | 2014-12-31 | 2016-07-27 | 华为技术有限公司 | 将数据写入固态硬盘的方法及固态硬盘 |
CN106326135A (zh) * | 2015-06-30 | 2017-01-11 | 华为技术有限公司 | 一种平移非易失性存储器nvm的数据的方法及装置 |
CN109375880A (zh) * | 2018-11-05 | 2019-02-22 | 郑州云海信息技术有限公司 | 一种数据均衡方法、装置和计算机可读存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN110515549A (zh) | 2019-11-29 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN113196226B (zh) | 固态驱动器中的分区命名空间 | |
CN110515549B (zh) | 一种数据迁移方法及装置 | |
KR102370760B1 (ko) | 존 네임스페이스에 대한 존 형성 | |
KR101908581B1 (ko) | 저장 디바이스들에서의 웨어 레벨링 | |
US11055176B1 (en) | Storage devices hiding parity swapping behavior | |
CN106873908B (zh) | 数据存储方法及装置 | |
KR20120126678A (ko) | 내구성을 향상한 비휘발성 메모리 장치 및 그 동작방법 | |
EP2395513A1 (en) | Memory device, memory management device, and memory management method | |
CN103257830A (zh) | 存储单元的访问方法和存储单元 | |
CN102214143A (zh) | 一种多层单元闪存的管理方法、装置及存储设备 | |
CN114730604A (zh) | 动态zns开放分区活动限制 | |
US11520523B2 (en) | Data integrity protection of ZNS needs | |
CN114730290A (zh) | 将变化日志表移动至与分区对准 | |
CN114730250A (zh) | 根据存储设备中的分区对读取命令加权 | |
CN104238952A (zh) | 磁盘分区格式转换方法及系统 | |
EP2381354A2 (en) | Data recording device | |
KR102589609B1 (ko) | 분할된 저장장치에서의 스냅샷 관리 | |
KR20240073166A (ko) | 저장 디바이스 열 로드에 기초한 제어된 시스템 관리 | |
CN109508140B (zh) | 存储资源管理方法、装置、电子设备及电子设备、系统 | |
US11687263B2 (en) | Full die recovery in ZNS SSD | |
CN112204514A (zh) | 用于保留非易失性存储器的预期寿命的技术 | |
US11409459B2 (en) | Data parking for SSDs with zones | |
US11226761B2 (en) | Weighted read commands and open block timer for storage devices | |
US20100037004A1 (en) | Storage system for backup data of flash memory and method for the same | |
US12055996B2 (en) | Storage device write-read error reduction system |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |