CN106201348A - 非易失性存储设备的缓存管理方法及装置 - Google Patents
非易失性存储设备的缓存管理方法及装置 Download PDFInfo
- Publication number
- CN106201348A CN106201348A CN201610519683.0A CN201610519683A CN106201348A CN 106201348 A CN106201348 A CN 106201348A CN 201610519683 A CN201610519683 A CN 201610519683A CN 106201348 A CN106201348 A CN 106201348A
- Authority
- CN
- China
- Prior art keywords
- subpool
- page
- capacity
- dirty pages
- clean
- 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
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/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
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/12—Replacement control
- G06F12/121—Replacement control using replacement algorithms
- G06F12/123—Replacement control using replacement algorithms with age lists, e.g. queue, most recently used [MRU] list or least recently used [LRU] list
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/0223—User address space allocation, e.g. contiguous or non contiguous base addressing
- G06F12/023—Free address space management
- G06F12/0238—Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory
- G06F12/0246—Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory in block erasable memory, e.g. flash memory
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/0802—Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
- G06F12/0866—Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches for peripheral storage systems, e.g. disk cache
- G06F12/0871—Allocation or management of cache space
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/12—Replacement control
- G06F12/121—Replacement control using replacement algorithms
-
- 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/0655—Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
- G06F3/0656—Data buffering arrangements
-
- 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]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/21—Employing a record carrier using a specific recording technology
- G06F2212/214—Solid state disk
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/22—Employing cache memory using specific memory technology
- G06F2212/222—Non-volatile memory
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/50—Control mechanisms for virtual memory, cache or TLB
- G06F2212/502—Control mechanisms for virtual memory, cache or TLB using adaptive policy
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/60—Details of cache memory
- G06F2212/604—Details relating to cache allocation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/72—Details relating to flash memory management
- G06F2212/7204—Capacity control, e.g. partitioning, end-of-life degradation
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Human Computer Interaction (AREA)
- Memory System Of A Hierarchy Structure (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本发明实施例公开了一种非易失性存储设备的缓存管理方法及装置,涉及数据处理技术领域,避免脏页频繁替换,提高存储设备工作寿命,降低实现成本,提高执行效率。本发明实施例包括:判断所述干净页子池与所述脏页子池容量之和与缓存容量之间的大小关系;当所述干净页子池与所述脏页子池容量之和大于或者等于所述缓存容量时,判断所述待访问页面的标识信息是否在干净页历史列表或者在脏页历史列表中;当确定所述待访问页面的标识信息在干净页历史列表中时,将干净子池容量阈值增加一个第一调整值;当所述待访问页面的标识信息在脏页历史列表中时,将所述干净子池容量阈值减少一个第二调整值。本发明实施例主要应用于非易失性存储设备的缓存管理过程中。
Description
技术领域
本发明实施例涉及数据处理技术领域,尤其涉及一种非易失性存储设备的缓存管理方法及装置。
背景技术
随着半导体技术的高速发展,使用磁性介质记录信息的存储设备(如硬盘等)的访问带宽的增长已远远跟不上处理器处理速度的增长。同时,基于半导体技术的各种非易失性存储技术,如闪存等存储设备高速发展,容量不断增大,成本不断降低,性价比不断提高。在这样的发展趋势下,基于半导体的非易失性存储设备正逐渐取代基于磁性介质的传统存储设备,成为主要存储设备。目前的非易失性存储设备都具有读写不对称的特性,实际上,使用非易失性存储设备时,读操作的延时远小于写操作的延时。
虽然非易失性存储设备的访问时延和实际带宽均优于传统存储设备,但仍比不上内存,更比不上处理器的片内缓存。因此,在处理器与非易失性存储设备之间,需要有中间的存储层次(主存或处理器片内缓存)作为缓存来提升非易失性存储设备的实际访问带宽。
针对于传统存储设备的缓存设计方案都围绕着提升缓存命中率的核心目标而优化,直接应用到采用非易失性存储设备的存储架构中,会造成因脏页的频繁替换而导致读写平均时延增大,设备工作寿命降低等问题。而将复杂的代价模型应用到采用非易失性存储设备的存储架构,实现成本高,执行效率低。
发明内容
本发明的实施例提供一种非易失性存储设备的缓存管理方法及装置,避免脏页频繁替换,提高存储设备工作寿命,降低实现成本,提高执行效率。
本发明的实施例采用如下技术方案:
一种非易失性存储设备的缓存管理方法,应用于基于非易失性存储设备的缓存系统,所述缓存系统包括:缓存、非易失性存储设备以及缓存管理装置;所述缓存用于保存从所述非易失性存储设备中读取的页面数据以及准备写入所述非易失性存储设备中的页面数据,包括干净页子池和脏页子池;所述非易失性存储设备用于保存所有页面数据;所述缓存管理装置使用以下信息管理所述缓存,所述信息包括干净子池容量阈值、干净页子池的页面信息,干净页历史列表,脏页子池的页面信息和脏页历史列表,其中,所述页面信息包括子池容量,所述干净页历史列表用于存储最近被替换出缓存的历史干净页的标识信息,所述脏页历史列表用于存储最近被替换出缓存的历史脏页的标识信息;
该方法包括:
当确定待访问页面不在干净页子池,并且也不在脏页子池时,判断所述干净页子池与所述脏页子池容量之和与缓存容量之间的大小关系;
当所述干净页子池与所述脏页子池容量之和大于或者等于所述缓存容量时,判断所述待访问页面的标识信息是否在干净页历史列表或者在脏页历史列表中;
当确定所述待访问页面的标识信息在干净页历史列表中时,将干净子池容量阈值增加一个第一调整值;
当所述待访问页面的标识信息在脏页历史列表中时,将所述干净子池容量阈值减少一个第二调整值。
一种非易失性存储设备的缓存管理装置,应用于基于非易失性存储设备的缓存系统,所述缓存系统包括:缓存、非易失性存储设备以及缓存管理装置;所述缓存用于保存从所述非易失性存储设备中读取的页面数据以及准备写入所述非易失性存储设备中的页面数据,包括干净页子池和脏页子池;所述非易失性存储设备用于保存所有页面数据;所述缓存管理装置使用以下信息管理所述缓存,所述信息包括干净子池容量阈值、干净页子池的页面信息,干净页历史列表,脏页子池的页面信息和脏页历史列表,其中,所述页面信息包括子池容量,所述干净页历史列表用于存储最近被替换出缓存的历史干净页的标识信息,所述脏页历史列表用于存储最近被替换出缓存的历史脏页的标识信息;
该装置包括:
判断单元,用于在确定待访问页面不在干净页子池,并且也不在脏页子池时,判断所述干净页子池与所述脏页子池容量之和与缓存容量之间的大小关系;
所述判断单元,还用于在确定所述干净页子池与所述脏页子池容量之和大于或者等于所述缓存容量时,判断所述待访问页面的标识信息是否在干净页历史列表或者在脏页历史列表中;
调整单元,用于在所述判断单元确定所述待访问页面的标识信息在干净页历史列表中时,将干净子池容量阈值增加一个第一调整值;
所述调整单元,还用于在所述判断单元确定所述待访问页面的标识信息在脏页历史列表中时,将所述干净子池容量阈值减少一个第二调整值。
本发明实施例提供的一种非易失性存储设备的缓存调整方法及装置,通过在干净子池容量超过容量阈值时,依据写操作延时和读操作延时对干净子池的容量进行调整,实现了对干净子池和脏页子池容量的控制。由于非易失性存储设备的读写不对称特性,使得在对干净子池和脏页子池容量的控制时,可以优先加大脏页子池的容量,从而避免脏页频繁替换,提高存储设备工作寿命。并且,调整值的计算方法简单,相关参数获取容易,降低实现成本,提高执行效率。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本发明实施例1中的一种基于非易失性存储设备的缓存系统的组成框图;
图2为本发明实施例1中的一种基于非易失性存储设备的缓存调整方法流程图;
图3为本发明实施例2中的一种基于非易失性存储设备的缓存调整方法流程图;
图4为本发明实施例2中的另一种基于非易失性存储设备的缓存调整方法流程图;
图5为本发明实施例2中的另一种基于非易失性存储设备的缓存调整方法流程图;
图6为本发明实施例3中的一种基于非易失性存储设备的缓存调整装置的组成框图;
图7为本发明实施例3中的另一种基于非易失性存储设备的缓存调整装置的组成框图;
图8为本发明实施例3中的另一种基于非易失性存储设备的缓存调整装置的组成框图;
图9为本发明实施例3中的另一种基于非易失性存储设备的缓存调整装置的组成框图;
图10为本发明实施例3中的另一种基于非易失性存储设备的缓存调整装置的组成框图;
图11为本发明实施例3中的另一种基于非易失性存储设备的缓存调整装置的组成框图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
实施例1
本发明实施例提供了一种非易失性存储设备的缓存管理方法,可以应用在基于非易失性存储设备的缓存系统,如图1所示,所述缓存系统包括:缓存、非易失性存储设备以及缓存管理装置。
所述缓存,可以用于保存从所述非易失性存储设备中读取的页面数据以及准备写入所述非易失性存储设备中的页面数据,包括干净页子池和脏页子池。所述干净页子池为缓存中未被修改的页面的集合,所述脏页子池为缓存中已被修改的页面的集合。所述干净页子池和脏页子池可以由链表l inked l ist或数组array等数据结构中的一种或多种的组合来实现。
所述非易失性存储设备,例如,闪存,PCM(Phase Change Memory,相变化存储器)等存储设备,可以用于保存所有页面数据。
所述缓存管理装置,可以使用以下信息管理所述缓存,所述信息包括干净子池容量阈值、干净页子池的页面信息,干净页历史列表,脏页子池的页面信息和脏页历史列表,其中,所述页面信息包括子池容量,所述干净页历史列表用于存储最近被替换出缓存的历史干净页的标识信息,所述脏页历史列表用于存储最近被替换出缓存的历史脏页的标识信息。为实现对干净页和脏页的独立管理,可以将缓存管理装置中设置干净页管理单元和脏页管理单元。其中,在本发明实施例中,列表这一名称是对应于本发明实施例所处技术领域内协议和标准中l ist一词的中文解释。列表l ist的实现形式是多样的,可以由l inkedlist或者array等数据结构来实现,本发明实施例对此不进行限制。
进一步的,在实现基于非易失性存储设备的缓存系统的过程中,需要进行预先设置,以保证该缓存系统的正常运行,这些设置具体包括:
干净页子池与脏页子池的容量之和不超过缓存的物理容量。干净页子池的容量与干净页历史列表的容量之和不超过缓存的物理容量。此外,干净页子池的页面信息,干净页历史列表,脏页子池的页面信息和脏页历史列表四者的容量之和不超过缓存的物理容量的2倍。干净页历史列表和脏页历史列表均为LRU(Least Recently Used,最近最少使用)列表。干净页子池和脏页子池使用独立的页面替换策略,如LRU,LFU(least frequentlyused,最不经常使用页置换算法)等,其页面信息的格式和维护与其选择的页面替换策略相匹配。当然,上述设置仅仅是实现基于非易失性存储设备的缓存系统的一种设置方法,具体的设置方法可以根据实际情况进行选择,并不局限于此。
在上述基于非易失性存储设备的缓存系统中,本发明实施例提供的一种非易失性存储设备的缓存管理方法,如图2所示,具体包括:
101、当确定待访问页面不在干净页子池,并且也不在脏页子池时,缓存管理装置判断所述干净页子池与所述脏页子池容量之和与缓存容量之间的大小关系。
102、当所述干净页子池与所述脏页子池容量之和大于或者等于所述缓存容量时,所述缓存管理装置判断所述待访问页面的标识信息是否在干净页历史列表或者在脏页历史列表中。
其中,所述待访问页面的标识信息可以设置为ID编号等具有标识功能的信息,本发明实施例在此不一一列举。
103、当确定所述待访问页面的标识信息在干净页历史列表中时,所述缓存管理装置将干净子池容量阈值增加一个第一调整值。
其中,所述第一调整值可以设置为读操作延时除以写操作延时得到的商值与1之间的较大值。并且,所述干净页子池容量阈值经过调整后不能超过缓存容量。
其中,读操作延时和写操作延时针对于同一个非易失性存储设备是固定不变的,而对于不同的非易失性存储设备可能存在不同。
104、当所述待访问页面的标识信息在脏页历史列表中时,所述缓存管理装置将所述干净子池容量阈值减少一个第二调整值。
其中,所述第二调整值可以设置为写操作延时除以读操作延时得到的商值与1之间的较大值。并且,所述脏页子池容量阈值经过调整后不能超过缓存容量。
本发明实施例提供的一种非易失性存储设备的缓存调整方法,通过在干净子池容量超过容量阈值时,依据写操作延时和读操作延时对干净子池的容量进行调整,实现了对干净子池和脏页子池容量的控制。由于非易失性存储设备的读写不对称特性,使得在对干净子池和脏页子池容量的控制时,可以优先加大脏页子池的容量,从而避免脏页频繁替换,提高存储设备工作寿命。并且,调整值的计算方法简单,相关参数获取容易,降低实现成本,提高执行效率。
实施例2
本发明实施例提供了一种非易失性存储设备的缓存调整方法,也可以应用于如图1所示的基于非易失性存储设备的缓存系统中,并且对该缓存系统的设置方法也可以与实施例1中相同,如图2所示,该方法具体包括:
201、当确定待访问页面不在干净页子池,并且也不在脏页子池时,缓存管理装置判断所述干净页子池与所述脏页子池容量之和与缓存容量之间的大小关系。当所述干净页子池与所述脏页子池容量之和大于或者等于所述缓存容量时,执行步骤202;当所述干净页子池与所述脏页子池容量之和小于所述缓存容量时,则执行步骤209。
202、所述缓存管理装置从所述干净页子池和脏页子池中选取一个用于选择待替换页面的子池。
其中,所述步骤202的实现方法具体如下,如图3所示,包括:
2011、所述缓存管理装置判断所述干净页子池容量与所述干净子池容量阈值之间的大小关系。当所述干净页子池容量大于所述干净子池容量阈值时,则执行步骤2022;当所述干净页子池容量小于所述干净子池容量阈值时,则执行步骤2023;当所述干净页子池容量等于所述干净子池容量阈值时,则执行步骤2024。
2022、所述缓存管理装置选取干净页子池作为用于选择待替换页面的子池。
2023、所述缓存管理装置选取脏页子池作为用于选择待替换页面的子池。
2024、所述缓存管理装置判断如下条件是否成立,所述条件为所述待访问页面在所述干净页历史列表中并且脏页子池容量大于0。若所述条件成立,则执行所述步骤2022;否则执行所述步骤2023。
203、根据选取到的子池对应的页面替换策略,所述缓存管理装置从所述选取到的子池中选取一个待替换页面。
其中,干净页子池和脏页子池对应的页面替换策略可以为LRU、ACR等,并且干净页子池和脏页子池对应的页面替换策略可以设置为相同的,也可以设置为不同的,本发明在此不进行限制。
需要说明的是,根据设置好的页面替换策略选择待替换页面的实现方法为本领域技术人员公知的技术,本发明实施例在此不进行限制。
204、所述缓存管理装置维护所述选取到的子池对应的页面替换策略当前所需的信息。
需要说明的是,所述页面替换策略当前所需的信息根据页面替换策略的不同而不同。维护页面替换策略当前所需的信息为本领域技术人员公知的技术,本发明实施例在此不详细描述。
205、所述缓存管理装置将所述待替换页面的标识信息迁移到所述选取到的子池对应的历史列表的最近使用位置。
其中,所述步骤205具体实现方法如下,包括:
当选取到的子池为干净页子池时,所述缓存管理装置将所述待替换页面的标识信息迁移到干净页历史列表的最近使用位置。
当选取到的子池为脏页子池时,所述缓存管理装置将所述待替换页面的标识信息迁移到脏页历史列表的最近使用位置。
206、所述缓存管理装置判断所述待访问页面的标识信息是否在干净页历史列表或者在脏页历史列表中。当确定所述待访问页面的标识信息在干净页历史列表中时,则执行步骤207;当所述待访问页面的标识信息在脏页历史列表中时,则执行步骤208。
207、所述缓存管理装置将干净子池容量阈值增加一个第一调整值,所述第一调整值为读操作延时除以写操作延时得到的商值与1之间的较大值,并执行步骤210。
208、所述缓存管理装置将所述干净子池容量阈值减少一个第二调整值,所述第二调整值为写操作延时除以读操作延时得到的商值与1之间的较大值,并执行步骤210。
209、所述缓存管理装置从所述非易失性存储设备中读取所述待访问页面,并执行步骤210。
210、所述缓存管理装置判断当前请求所述待访问页面的操作对应的操作类型。当确定所述操作类型为读操作时,则执行步骤211;当确定所述操作类型为写操作时,则执行步骤215。
211、所述缓存管理装置将所述待访问页面读取到所述干净页子池中,并维护所述干净页子池对应的页面替换策略当前所需的信息。
212、所述缓存管理装置判断干净页子池容量与干净页历史列表容量之和是否大于所述缓存容量。若确定所述干净页子池容量与所述干净页历史列表容量之和大于所述缓存容量,则执行步骤213;若确定所述干净页子池容量与所述干净页历史列表容量之和小于或者等于所述缓存容量,则执行步骤214。
213、所述缓存管理装置移除干净页历史列表的最近最少使用位置的页面标识信息,并结束缓存管理流程。
214、所述缓存管理装置保持干净页历史列表不变,并结束缓存管理流程。
215、所述缓存管理装置将所述待访问页面读取到所述脏页子池中,并维护所述脏页子池对应的页面替换策略当前所需的信息。
216、所述缓存管理装置判断干净页子池容量、脏页子池容量、干净页历史列表容量以及脏页历史列表容量之和是否大于所述缓存容量的两倍。若确定干净页子池容量、脏页子池容量、干净页历史列表容量以及脏页历史列表容量之和大于所述缓存容量的两倍,则执行步骤217;若确定干净页子池容量、脏页子池容量、干净页历史列表容量以及脏页历史列表容量之和小于或者等于所述缓存容量的两倍,则执行步骤218。
217、所述缓存管理装置移除脏页历史列表的最近最少使用位置的页面标识信息,并结束缓存管理流程。
218、所述缓存管理装置保持脏页历史列表不变,并结束缓存管理流程。
在本实施例中,通过在干净子池容量超过容量阈值时,依据写操作延时和读操作延时对干净子池的容量进行调整,实现了对干净子池和脏页子池容量的控制。由于非易失性存储设备的读写不对称特性,使得在对干净子池和脏页子池容量的控制时,可以优先加大脏页子池的容量,从而避免脏页频繁替换,提高存储设备工作寿命。
并且,只需要根据写操作延时和读操作延时对干净子池的容量进行调整,调整值的计算方法简单,相关参数获取容易,降低实现成本,提高执行效率。
而且,对历史列表的容量大小也进行控制,降低了缓存管理装置需要管理的信息,保证缓存管理装置工作性能。
需要说明的是,在处理器请求访问页面的过程可分为两个部分流程,其中一个部分流程为当待访问页面在缓存中时,直接从缓存中读取待访问页面;另一部分流程为当待访问页面不在缓存中时,需要进行页面缺失流程。上述步骤201至步骤218属于页面缺失流程。
进一步的,处理器请求访问页面的过程对应的缓存管理流程如图4所示,具体包括:
301、所述缓存管理装置判断所述待访问页面是否在干净页子池中。若确定所述待访问页面在干净页子池中,则执行步骤302;否则执行步骤305。
302、所述缓存管理装置判断当前请求所述待访问页面的操作对应的操作类型。当确定所述操作类型为读操作时,则执行步骤303;当确定所述操作类型为写操作时,则执行步骤304。
303、所述缓存管理装置维护所述干净页子池对应的页面替换策略当前所需的信息。
304、所述缓存管理装置将所述待访问页面迁移到脏页子池中,并维护所述干净页子池对应的页面替换策略当前所需的信息以及所述脏页子池对应的页面替换策略当前所需的信息,并结束缓存管理流程。
305、所述缓存管理装置判断所述待访问页面是否在脏页子池中。若确定所述待访问页面在脏页子池中,则执行步骤306;否则执行步骤307。
306、所述缓存管理装置维护所述脏页子池对应的页面替换策略当前所需的信息,并结束缓存管理流程。
307、进入待访问页面缺失流程,即所述步骤201至步骤218,以使得所述缓存管理装置将所述待访问页面读取到缓存中,并结束缓存管理流程。
在本实施例中,步骤301至步骤307实现了处理器请求访问页面的过程对应的缓存管理流程。
本发明实施例提供的一种非易失性存储设备的缓存管理方法,通过在干净子池容量超过容量阈值时,依据写操作延时和读操作延时对干净子池的容量进行调整,实现了对干净子池和脏页子池容量的控制。由于非易失性存储设备的读写不对称特性,使得在对干净子池和脏页子池容量的控制时,可以优先加大脏页子池的容量,从而避免脏页频繁替换,提高存储设备工作寿命。
并且,只需要根据写操作延时和读操作延时对干净子池的容量进行调整,调整值的计算方法简单,相关参数获取容易,降低实现成本,提高执行效率。
而且,对历史列表的容量大小也进行控制,降低了缓存管理装置需要管理的信息,保证缓存管理装置工作性能。
实施例3
本发明实施例提供了一种非易失性存储设备的缓存管理装置,如图6所示,该装置包括:判断单元41、调整单元42。
判断单元41,用于在确定待访问页面不在干净页子池,并且也不在脏页子池时,判断所述干净页子池与所述脏页子池容量之和与缓存容量之间的大小关系。
所述判断单元41,还用于在确定所述干净页子池与所述脏页子池容量之和大于或者等于所述缓存容量时,判断所述待访问页面的标识信息是否在干净页历史列表或者在脏页历史列表中。
调整单元42,用于在所述判断单元41确定所述待访问页面的标识信息在干净页历史列表中时,将干净子池容量阈值增加一个第一调整值,所述第一调整值为读操作延时除以写操作延时得到的商值与1之间的较大值。
所述调整单元42,还用于在所述判断单元41确定所述待访问页面的标识信息在脏页历史列表中时,将所述干净子池容量阈值减少一个第二调整值,所述第二调整值为写操作延时除以读操作延时得到的商值与1之间的较大值。
可选的是,如图7所示,该装置还包括:选取单元43、维护单元44、迁移单元45。
选取单元43,用于在所述判断单元41确定所述干净页子池与所述脏页子池容量之和大于或者等于所述缓存容量,从所述干净页子池和脏页子池中选取一个用于选择待替换页面的子池;
所述选取单元43,用于根据选取到的子池对应的页面替换策略,从所述选取到的子池中选取一个待替换页面;
维护单元44,用于维护所述选取单元44选取到的子池对应的页面替换策略当前所需的信息;
迁移单元45,用于将所述待替换页面的标识信息迁移到所述选取到的子池对应的历史列表的最近使用位置。
可选的是,如图8所示,所述选取单元43还包括:判断模块431、子池选取模块432。
判断模块431,用于判断所述干净页子池容量与所述干净子池容量阈值之间的大小关系。
子池选取模块432,用于在所述判断模块431确定所述干净页子池容量大于所述干净子池容量阈值时,选取干净页子池作为用于选择待替换页面的子池。
所述选取模块432,用于在所述判断模块431确定所述干净页子池容量小于所述干净子池容量阈值时,选取脏页子池作为用于选择待替换页面的子池。
所述判断模块431,用于在所述干净页子池容量等于所述干净子池容量阈值时,判断如下条件是否成立,所述条件为所述待访问页面在所述干净页历史列表中并且脏页子池容量大于0。
所述子池选取模块432,用于在所述判断模块431确定所述条件成立时,选取脏页子池作为用于选择待替换页面的子池。
所述子池选取模块432,用于在所述判断模块431确定所述条件不成立时,选取干净页子池作为用于选择待替换页面的子池。
可选的是,如图9所示,该装置还包括:读取单元46。
读取单元46,用于在所述判断单元41确定所述干净页子池与所述脏页子池容量之和小于所述缓存容量时,从所述非易失性存储设备中读取所述待访问页面。
可选的是,所述判断单元41,还用于判断当前请求所述待访问页面的操作对应的操作类型。
所述读取单元46,用于在所述判断单元41确定所述操作类型为读操作时,将所述待访问页面读取到所述干净页子池中。
所述维护单元44,用于维护所述干净页子池对应的页面替换策略当前所需的信息。
所述读取单元46,用于所述判断单元确定操作类型为写操作时,将所述待访问页面读到所述脏页子池中。
所述维护单元,用于维护所述脏页子池对应的页面替换策略当前所需的信息。
可选的是,如图10所示,该装置还包括:第一移除单元47。
所述判断单元41,用于判断干净页子池容量与干净页历史列表容量之和是否大于所述缓存容量。
第一移除单元47,用于在所述判断单元41确定所述干净页子池容量与所述干净页历史列表容量之和大于所述缓存容量时,移除干净页历史列表的最近最少使用位置的页面标识信息。
所述第一移除单元47,还用于在所述判断单元41确定所述干净页子池容量与所述干净页历史列表容量之和小于或者等于所述缓存容量时,保持干净页历史列表不变。
可选的是,如图11所示,该装置还包括:第二移除单元48。
所述判断单元41,用于判断干净页子池容量、脏页子池容量、干净页历史列表容量以及脏页历史列表容量之和是否大于所述缓存容量的两倍。
第二移除单元48,用于在所述判断单元41确定干净页子池容量、脏页子池容量、干净页历史列表容量以及脏页历史列表容量之和大于所述缓存容量的两倍时,移除脏页历史列表的最近最少使用位置的页面标识信息。
所述第二移除单元48,用于在所述判断单元41确定干净页子池容量、脏页子池容量、干净页历史列表容量以及脏页历史列表容量之和小于或者等于所述缓存容量的两倍时,保持脏页历史列表不变。
可选的是,所述判断单元41,用于判断所述待访问页面是否在干净页子池中;
所述判断单元41,还用于在确定所述待访问页面不在干净页子池中时,判断所述待访问页面是否在脏页子池中;
所述维护单元44,用于在所述判断单元41确定所述待访问页面在脏页子池中时,则维护所述脏页子池对应的页面替换策略当前所需的信息;
所述判断单元41,用于在确定所述待访问页面不在脏页子池中时,判断所述干净页子池与所述脏页子池容量之和与缓存容量之间的大小关系。
可选的是,所述判断单元41,还用于在确定所述待访问页面在干净页子池中时,获取当前请求所述待访问页面的操作对应的操作类型。
所述维护单元44,还用于在判断单元41确定所述操作类型为读操作时,维护所述干净页子池对应的页面替换策略当前所需的信息。
所述迁移单元45,用于在所述判断单元41确定所述操作类型为写操作时,将所述待访问页面迁移到脏页子池中。
所述维护单元44,还用于维护所述干净页子池对应的页面替换策略当前所需的信息以及所述脏页子池对应的页面替换策略当前所需的信息。
本发明实施例提供的一种非易失性存储设备的缓存管理装置,通过在干净子池容量超过容量阈值时,依据写操作延时和读操作延时对干净子池的容量进行调整,实现了对干净子池和脏页子池容量的控制。由于非易失性存储设备的读写不对称特性,使得在对干净子池和脏页子池容量的控制时,可以优先加大脏页子池的容量,从而避免脏页频繁替换,提高存储设备工作寿命。
并且,只需要根据写操作延时和读操作延时对干净子池的容量进行调整,调整值的计算方法简单,相关参数获取容易,降低实现成本,提高执行效率。
而且,对历史列表的容量大小也进行控制,降低了缓存管理装置需要管理的信息,保证缓存管理装置工作性能。
通过以上的实施方式的描述,所属领域的技术人员可以清楚地了解到本发明可借助软件加必需的通用硬件的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在可读取的存储介质中,如计算机的软盘,硬盘或光盘等,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述的方法。
以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应以所述权利要求的保护范围为准。
Claims (24)
1.一种应用于存储系统中的缓存管理方法,其特征在于,所述存储系统包括:缓存、非易失性存储设备以及缓存管理装置;所述缓存用于缓存从所述非易失性存储设备中读取的数据以及准备写入所述非易失性存储设备中的数据;
所述方法包括:
所述缓存管理装置确定待访问页面不在所述缓存的干净页子池中,并且所述待访问页面也不在所述缓存的脏页子池中,其中,所述缓存包括所述干净页子池和所述脏页子池,所述干净页子池用于缓存所述缓存中未被修改的页面,所述脏页子池用于缓存所述缓存中被修改的页面;
所述缓存管理装置确定所述脏页子池、所述干净页子池以及所述缓存之间的容量关系;
当所述容量关系指示所述脏页子池的容量和所述干净页子池的容量之和等于所述缓存的容量时,所述缓存管理装置判断所述待访问页面的标识信息是否在所述干净页历史列表或所述脏页历史列表中,其中,所述干净页历史列表用于记录最近被替换出所述缓存的干净页的标识信息,所述脏页历史列表用于记录被替换出所述缓存的脏页的标识信息;
当所述待访问页面的标识在所述干净页历史列表中时,所述缓存管理装置增加所述干净页子池的最大容量;
当所述待访问页面的标识在所述脏页历史列表中时,所述缓存管理装置减少所述干净页子池的最大容量。
2.根据权利要求1所述的方法,其特征在于,还包括:
所述缓存管理装置从所述干净页子池和脏页子池中选取一个用于选择待替换页面的子池;
所述缓存管理装置根据选取的子池对应的页面替换策略,从所述被选取的子池中选取一个待替换页面;
将所述待替换页面的标识信息迁移到所述被选取的子池对应的历史列表的最近使用位置。
3.根据权利要求2所述的方法,其特征在于,所述缓存管理装置从所述干净页子池和脏页子池中选取一个用于选择待替换页面的子池具体包括:
当所述干净页子池的容量大于所述干净页子池的最大容量时,所述缓存管理装置选择所述干净页子池作为用于选择待替换页面的子池。
4.根据权利要求2所述的方法,其特征在于,所述缓存管理装置从所述干净页子池和脏页子池中选取一个用于选择待替换页面的子池具体包括:
当所述干净页子池的容量小于所述干净页子池的最大容量时,所述缓存管理装置选择所述脏页子池作为用于选择待替换页面的子池。
5.根据权利要求2所述的方法,其特征在于,所述缓存管理装置从所述干净页子池和脏页子池中选取一个用于选择待替换页面的子池具体包括:
当所述干净页子池容量等于所述干净子池容量阈值时,所述缓存管理装置判断所述待访问页面是否在所述干净页历史列表中并且所述脏页子池容量是否大于0;
当所述待访问页面在所述干净页历史列表中并且所述脏页子池容量大于0时,所述缓存管理装置选择所述脏页子池作为所述用于选择待替换页面的子池;
当所述待访问页面不在所述干净页历史列表或所述脏页子池容量不大于0时,所述缓存管理装置选择所述干净页子池作为所述用于选择待替换页面的子池。
6.根据权利要求1-5任意一项所述的方法,其特征在于,还包括:
所述缓存管理装置判断当前请求所述待访问页面的操作的操作类型;
当确定所述操作类型为读操作时,所述缓存管理装置将从所述非易失性存储设备中读取的所述待访问页面缓存到所述干净页子池中;
当确定所述操作类型为写操作时,所述缓存管理装置将从所述非易失性存储设备中读取的所述待访问页面缓存到所述脏页子池中。
7.根据权利要求1-6任意一项所述的方法,其特征在于,还包括:
所述缓存管理装置判断所述干净页子池的容量与所述干净页历史列表的容量之和是否大于所述缓存的容量;
当所述干净页子池的容量与所述干净页历史列表的容量之和大于所述缓存的容量时,所述缓存管理装置删除所述干净页历史列表的最近最少使用位置的页面标识信息。
8.根据权利要求1-6任意一项所述的方法,其特征在于,还包括:
所述缓存管理装置判断所述干净页子池的容量、所述脏页子池的容量、所述干净页历史列表的容量以及所述脏页历史列表的容量之和是否大于所述缓存的容量的两倍;
当所述干净页子池的容量、所述脏页子池的容量、所述干净页历史列表的容量以及所述脏页历史列表的容量之和大于所述缓存的容量的两倍时,所述缓存管理装置删除所述脏页历史列表中的最近最少使用位置的页面标识信息。
9.一种缓存管理装置,其特征在于,所述缓存管理装置应用于存储系统中,所述存储系统包括:缓存、非易失性存储设备以及所述缓存管理装置;所述缓存用于缓存从所述非易失性存储设备中读取的数据以及准备写入所述非易失性存储设备中的数据,
所述缓存管理装置包括:
判断单元,用于在确定待访问页面不在所述缓存的干净页子池中,并且所述待访问页面也不在所述缓存的脏页子池中,其中,所述缓存包括所述干净页子池和所述脏页子池,所述干净页子池用于缓存所述缓存中未被修改的页面,所述脏页子池用于缓存所述缓存中被修改的页面;
所述判断单元,还用于确定所述脏页子池、所述干净页子池以及所述缓存之间的容量关系;
当所述容量关系指示所述脏页子池的容量和所述干净页子池的容量之和等于所述缓存的容量时,判断所述待访问页面的标识信息是否在干净页历史列表或者在脏页历史列表中,其中,所述干净页历史列表用于记录最近被替换出所述缓存的干净页的标识信息,所述脏页历史列表用于记录被替换出所述缓存的脏页的标识信息;
调整单元,用于当所述待访问页面的标识在所述干净页历史列表中时,所述缓存管理装置增加所述干净页子池的最大容量;当所述待访问页面的标识在所述脏页历史列表中时,所述缓存管理装置减少所述干净页子池的最大容量。
10.根据权利要求9所述的装置,其特征在于,该装置还包括:
选取单元,用于从所述干净页子池和脏页子池中选取一个用于选择待替换页面的子池,并根据选取的子池对应的页面替换策略,从所述被选取的子池中选取一个待替换页面;
迁移单元,用于将所述待替换页面的标识信息迁移到所述被选取的子池对应的历史列表的最近使用位置。
11.根据权利要求10所述的装置,其特征在于,所述选取单元具体用于:
当所述干净页子池的容量大于所述干净页子池的最大容量时,选择所述干净页子池作为用于选择待替换页面的子池。
12.根据权利要求10所述的装置,其特征在于,所述选取单元具体用于:
当所述干净页子池的容量小于所述干净页子池的最大容量时,选择所述脏页子池作为用于选择待替换页面的子池。
13.根据权利要求10所述的装置,其特征在于,所述判断单元还用于:
当所述干净页子池容量等于所述干净子池容量阈值时,判断所述待访问页面是否在所述干净页历史列表中并且所述脏页子池容量是否大于0;
所述选取单元具体用于:
当所述待访问页面在所述干净页历史列表中并且所述脏页子池容量大于0时,选择所述脏页子池作为所述用于选择待替换页面的子池;
当所述待访问页面不在所述干净页历史列表或所述脏页子池容量不大于0时,选择所述干净页子池作为所述用于选择待替换页面的子池。
14.根据权利要求9-13任意一项所述的装置,其特征在于:
所述判断单元,还用于判断当前请求所述待访问页面的操作对应的操作类型;
所述读取单元,还用于当所述操作类型为读操作时,将从所述非易失性存储设备中读取的所述待访问页面缓存到所述干净页子池中;当所述操作类型为写操作时,将从所述非易失性存储设备中读取的所述待访问页面缓存到所述脏页子池中。
15.根据权利要求9-14任意一项所述的装置,其特征在于:
所述判断单元,还用于判断所述干净页子池的容量与所述干净页历史列表的容量之和是否大于所述缓存的容量;
所述装置还包括:
第一移除单元,用于当所述干净页子池的容量与所述干净页历史列表的容量之和大于所述缓存的容量时,删除所述干净页历史列表的最近最少使用位置的页面标识信息。
16.根据权利要求9-14任意一项所述的装置,其特征在于:
所述判断单元,还用于判断所述干净页子池的容量、所述脏页子池的容量、所述干净页历史列表的容量以及所述脏页历史列表的容量之和是否大于所述缓存的容量的两倍;
所述装置还包括:
第二移除单元,用于当所述干净页子池的容量、所述脏页子池的容量、所述干净页历史列表的容量以及所述脏页历史列表的容量之和大于所述缓存的容量的两倍时,移除所述脏页历史列表中的最近最少使用位置的页面标识信息。
17.一种存储系统,其特征在于,包括缓存、非易失性存储器以及缓存控制器,其中,所述缓存用于缓存从所述非易失性存储设备中读取的数据以及准备写入所述非易失性存储设备中的数据,所述缓存控制器用于:
确定待访问页面不在所述缓存的干净页子池中,并且所述待访问页面也不在所述缓存的脏页子池中,其中,所述缓存包括所述干净页子池和所述脏页子池,所述干净页子池用于缓存所述缓存中未被修改的页面,所述脏页子池用于缓存所述缓存中被修改的页面;
确定所述脏页子池、所述干净页子池以及所述缓存之间的容量关系;
当所述容量关系指示所述脏页子池的容量和所述干净页子池的容量之和等于所述缓存的容量时,判断所述待访问页面的标识信息是否在所述干净页历史列表或所述脏页历史列表中,其中,所述干净页历史列表用于记录最近被替换出所述缓存的干净页的标识信息,所述脏页历史列表用于记录被替换出所述缓存的脏页的标识信息;
当所述待访问页面的标识在所述干净页历史列表中时,增加所述干净页子池的最大容量;
当所述待访问页面的标识在所述脏页历史列表中时,减少所述干净页子池的最大容量。
18.根据权利要求17所述的存储系统,其特征在于,所述缓存控制器还用于:
从所述干净页子池和脏页子池中选取一个用于选择待替换页面的子池;
根据选取的子池对应的页面替换策略,从所述被选取的子池中选取一个待替换页面;
将所述待替换页面的标识信息迁移到所述被选取的子池对应的历史列表的最近使用位置。
19.根据权利要求18所述的存储系统,其特征在于,所述缓存控制器具体用于:
当所述干净页子池的容量大于所述干净页子池的最大容量时,选择所述干净页子池作为用于选择待替换页面的子池。
20.根据权利要求18所述的存储系统,其特征在于,所述缓存控制器具体用于:
当所述干净页子池的容量小于所述干净页子池的最大容量时,选择所述脏页子池作为用于选择待替换页面的子池。
21.根据权利要求18所述的存储系统,其特征在于,所述缓存控制器具体用于:
当所述干净页子池容量等于所述干净子池容量阈值时,判断所述待访问页面是否在所述干净页历史列表中并且所述脏页子池容量是否大于0;
当所述待访问页面在所述干净页历史列表中并且所述脏页子池容量大于0时,选择所述脏页子池作为所述用于选择待替换页面的子池;
当所述待访问页面不在所述干净页历史列表或所述脏页子池容量不大于0时,选择所述干净页子池作为所述用于选择待替换页面的子池。
22.根据权利要求17-21任意一项所述的方法,其特征在于,所述缓存控制器还用于:
判断当前请求所述待访问页面的操作的操作类型;
当确定所述操作类型为读操作时,将从所述非易失性存储设备中读取的所述待访问页面缓存到所述干净页子池中;
当确定所述操作类型为写操作时,将从所述非易失性存储设备中读取的所述待访问页面缓存到所述脏页子池中。
23.根据权利要求17-22任意一项所述的存储系统,其特征在于,所述缓存控制器还用于:
判断所述干净页子池的容量与所述干净页历史列表的容量之和是否大于所述缓存的容量;
当所述干净页子池的容量与所述干净页历史列表的容量之和大于所述缓存的容量时,删除所述干净页历史列表的最近最少使用位置的页面标识信息。
24.根据权利要求17-22任意一项所述的存储系统,其特征在于,所述缓存控制器还用于:
判断所述干净页子池的容量、所述脏页子池的容量、所述干净页历史列表的容量以及所述脏页历史列表的容量之和是否大于所述缓存的容量的两倍;
当所述干净页子池的容量、所述脏页子池的容量、所述干净页历史列表的容量以及所述脏页历史列表的容量之和大于所述缓存的容量的两倍时,删除所述脏页历史列表中的最近最少使用位置的页面标识信息。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610519683.0A CN106201348B (zh) | 2012-06-20 | 2012-06-20 | 非易失性存储设备的缓存管理方法及装置 |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610519683.0A CN106201348B (zh) | 2012-06-20 | 2012-06-20 | 非易失性存储设备的缓存管理方法及装置 |
CN201210205360.6A CN103514110B (zh) | 2012-06-20 | 2012-06-20 | 非易失性存储设备的缓存管理方法及装置 |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201210205360.6A Division CN103514110B (zh) | 2012-06-20 | 2012-06-20 | 非易失性存储设备的缓存管理方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN106201348A true CN106201348A (zh) | 2016-12-07 |
CN106201348B CN106201348B (zh) | 2019-08-20 |
Family
ID=49768078
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201210205360.6A Active CN103514110B (zh) | 2012-06-20 | 2012-06-20 | 非易失性存储设备的缓存管理方法及装置 |
CN201610519683.0A Active CN106201348B (zh) | 2012-06-20 | 2012-06-20 | 非易失性存储设备的缓存管理方法及装置 |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201210205360.6A Active CN103514110B (zh) | 2012-06-20 | 2012-06-20 | 非易失性存储设备的缓存管理方法及装置 |
Country Status (5)
Country | Link |
---|---|
US (2) | US9524245B2 (zh) |
EP (2) | EP3425513B1 (zh) |
CN (2) | CN103514110B (zh) |
ES (1) | ES2686724T3 (zh) |
WO (1) | WO2013189186A1 (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108345546A (zh) * | 2017-05-09 | 2018-07-31 | 清华大学 | 用于确定处理器操作的方法及装置 |
Families Citing this family (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9996262B1 (en) * | 2015-11-09 | 2018-06-12 | Seagate Technology Llc | Method and apparatus to abort a command |
CN107179963B (zh) * | 2016-03-11 | 2021-02-23 | 华为技术有限公司 | 非易失性静态随机存储器的备份方法和装置 |
JP6711121B2 (ja) * | 2016-05-10 | 2020-06-17 | 富士通株式会社 | 情報処理装置、キャッシュメモリ制御方法、およびキャッシュメモリ制御プログラム |
CN108021514B (zh) * | 2016-10-28 | 2020-11-06 | 华为技术有限公司 | 一种缓存替换的方法和设备 |
JP6799256B2 (ja) * | 2016-11-28 | 2020-12-16 | 富士通株式会社 | ストレージ制御装置、ストレージシステム、ストレージ制御方法およびストレージ制御プログラム |
US10254961B2 (en) * | 2017-02-21 | 2019-04-09 | International Business Machines Corporation | Dynamic load based memory tag management |
CN110955486B (zh) * | 2018-09-26 | 2022-08-23 | Oppo广东移动通信有限公司 | 文件缓存效率的追踪方法、装置、存储介质及终端 |
CN111258929B (zh) * | 2018-12-03 | 2023-09-26 | 北京京东尚科信息技术有限公司 | 缓存控制方法、装置和计算机可读存储介质 |
CN113032088B (zh) * | 2019-12-25 | 2023-12-22 | 阿里巴巴集团控股有限公司 | 脏页记录方法、装置、电子设备及计算机可读介质 |
CN117743206B (zh) * | 2024-02-21 | 2024-04-26 | 深圳市金政软件技术有限公司 | 数据的储存方法和装置 |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20060069876A1 (en) * | 2004-09-30 | 2006-03-30 | Sorav Bansal | Method and system of clock with adaptive cache replacement and temporal filtering |
KR20100006625A (ko) * | 2008-07-10 | 2010-01-21 | 한양대학교 산학협력단 | 플래시 메모리와 연동되는 페이지 버퍼 관리 장치 및 방법,그리고 플래시 메모리의 페이지 교체 장치 및 방법 |
CN102012873A (zh) * | 2010-11-24 | 2011-04-13 | 清华大学 | Nand闪存的缓存系统及缓存方法 |
CN102156753A (zh) * | 2011-04-29 | 2011-08-17 | 中国人民解放军国防科学技术大学 | 面向固态硬盘文件系统的数据页缓存方法 |
CN102160038A (zh) * | 2008-09-15 | 2011-08-17 | 惠普开发有限公司 | 管理非易失性磁盘高速缓存的方法和设备 |
US20110320766A1 (en) * | 2010-06-29 | 2011-12-29 | Youfeng Wu | Apparatus, method, and system for improving power, performance efficiency by coupling a first core type with a second core type |
CN102411541A (zh) * | 2010-10-13 | 2012-04-11 | 微软公司 | 使用分开的读和写高速缓存的动态高速缓存配置 |
CN102436356A (zh) * | 2011-12-12 | 2012-05-02 | 成都市华为赛门铁克科技有限公司 | 写页面空间分配方法和装置 |
Family Cites Families (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6996676B2 (en) | 2002-11-14 | 2006-02-07 | International Business Machines Corporation | System and method for implementing an adaptive replacement cache policy |
US7096321B2 (en) | 2003-10-21 | 2006-08-22 | International Business Machines Corporation | Method and system for a cache replacement technique with adaptive skipping |
US7058766B2 (en) | 2003-10-21 | 2006-06-06 | International Business Machines Corporation | Method and system of adaptive replacement cache with temporal filtering |
US7260679B2 (en) | 2004-10-12 | 2007-08-21 | International Business Machines Corporation | Apparatus and method to manage a data cache using a first and second least recently used list |
US7487320B2 (en) | 2004-12-15 | 2009-02-03 | International Business Machines Corporation | Apparatus and system for dynamically allocating main memory among a plurality of applications |
EP1870813B1 (en) * | 2006-06-19 | 2013-01-30 | Texas Instruments France | Page processing circuits, devices, methods and systems for secure demand paging and other operations |
US8745315B2 (en) * | 2006-11-06 | 2014-06-03 | Rambus Inc. | Memory Systems and methods supporting volatile and wear-leveled nonvolatile physical memory |
WO2008056593A1 (fr) * | 2006-11-06 | 2008-05-15 | Panasonic Corporation | Dispositif d'enregistrement |
US7783839B2 (en) | 2007-01-08 | 2010-08-24 | International Business Machines Corporation | Using different algorithms to destage different types of data from cache |
JP2009075759A (ja) * | 2007-09-19 | 2009-04-09 | Hitachi Ltd | ストレージ装置及びストレージ装置におけるデータの管理方法 |
EP2225643B1 (en) * | 2007-12-28 | 2020-05-06 | Toshiba Memory Corporation | Semiconductor storage device |
JP4729062B2 (ja) * | 2008-03-07 | 2011-07-20 | 株式会社東芝 | メモリシステム |
EP2577470A4 (en) * | 2010-06-04 | 2013-12-25 | Sandisk Entpr Ip Llc | CACHE ADMINISTRATION AND ACCELERATION IN STORAGE MEDIA |
US20140115241A1 (en) * | 2011-05-30 | 2014-04-24 | Qingsong Wei | Buffer management apparatus and method |
KR101824295B1 (ko) * | 2011-08-12 | 2018-01-31 | 샌디스크 테크놀로지스 엘엘씨 | 솔리드 스테이트 장치 가상화를 포함하는 캐시 관리 |
US9122631B2 (en) * | 2011-11-07 | 2015-09-01 | Peking University | Buffer management strategies for flash-based storage systems |
CN104011690B (zh) * | 2011-12-29 | 2016-11-09 | 英特尔公司 | 具有直接存取的多级存储器 |
-
2012
- 2012-06-20 CN CN201210205360.6A patent/CN103514110B/zh active Active
- 2012-06-20 CN CN201610519683.0A patent/CN106201348B/zh active Active
-
2013
- 2013-02-20 EP EP17197683.0A patent/EP3425513B1/en active Active
- 2013-02-20 WO PCT/CN2013/071688 patent/WO2013189186A1/zh active Application Filing
- 2013-02-20 ES ES13807299.6T patent/ES2686724T3/es active Active
- 2013-02-20 EP EP13807299.6A patent/EP2846266B1/en active Active
-
2014
- 2014-11-18 US US14/546,797 patent/US9524245B2/en active Active
-
2016
- 2016-11-10 US US15/348,056 patent/US9727487B2/en active Active
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20060069876A1 (en) * | 2004-09-30 | 2006-03-30 | Sorav Bansal | Method and system of clock with adaptive cache replacement and temporal filtering |
KR20100006625A (ko) * | 2008-07-10 | 2010-01-21 | 한양대학교 산학협력단 | 플래시 메모리와 연동되는 페이지 버퍼 관리 장치 및 방법,그리고 플래시 메모리의 페이지 교체 장치 및 방법 |
CN102160038A (zh) * | 2008-09-15 | 2011-08-17 | 惠普开发有限公司 | 管理非易失性磁盘高速缓存的方法和设备 |
US20110320766A1 (en) * | 2010-06-29 | 2011-12-29 | Youfeng Wu | Apparatus, method, and system for improving power, performance efficiency by coupling a first core type with a second core type |
CN102411541A (zh) * | 2010-10-13 | 2012-04-11 | 微软公司 | 使用分开的读和写高速缓存的动态高速缓存配置 |
CN102012873A (zh) * | 2010-11-24 | 2011-04-13 | 清华大学 | Nand闪存的缓存系统及缓存方法 |
CN102156753A (zh) * | 2011-04-29 | 2011-08-17 | 中国人民解放军国防科学技术大学 | 面向固态硬盘文件系统的数据页缓存方法 |
CN102436356A (zh) * | 2011-12-12 | 2012-05-02 | 成都市华为赛门铁克科技有限公司 | 写页面空间分配方法和装置 |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108345546A (zh) * | 2017-05-09 | 2018-07-31 | 清华大学 | 用于确定处理器操作的方法及装置 |
CN108345546B (zh) * | 2017-05-09 | 2019-09-20 | 清华大学 | 用于确定处理器操作的方法及装置 |
Also Published As
Publication number | Publication date |
---|---|
EP3425513B1 (en) | 2020-07-08 |
CN103514110A (zh) | 2014-01-15 |
EP2846266A1 (en) | 2015-03-11 |
US20170060773A1 (en) | 2017-03-02 |
EP2846266A4 (en) | 2015-07-15 |
US9727487B2 (en) | 2017-08-08 |
EP2846266B1 (en) | 2018-06-27 |
CN103514110B (zh) | 2016-08-24 |
ES2686724T3 (es) | 2018-10-19 |
US9524245B2 (en) | 2016-12-20 |
US20150074345A1 (en) | 2015-03-12 |
EP3425513A1 (en) | 2019-01-09 |
WO2013189186A1 (zh) | 2013-12-27 |
CN106201348B (zh) | 2019-08-20 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN106201348A (zh) | 非易失性存储设备的缓存管理方法及装置 | |
US9430376B2 (en) | Priority-based garbage collection for data storage systems | |
US10216639B2 (en) | Identification of blocks to be retained in a cache based on temperature | |
CN105487986B (zh) | 考虑总字节写入需求时设置高速缓冲存储器的大小 | |
US8225044B2 (en) | Storage system which utilizes two kinds of memory devices as its cache memory and method of controlling the storage system | |
CN108762664B (zh) | 一种固态硬盘页级缓存区管理方法 | |
CN103207839B (zh) | 存储的高速缓存内的轨道清除的高速缓存管理方法和系统 | |
CN107391398B (zh) | 一种闪存缓存区的管理方法及系统 | |
CN110413537B (zh) | 一种面向混合固态硬盘的闪存转换层及转换方法 | |
CN109062505A (zh) | 一种缓存策略写入分层硬件架构下的写性能优化方法 | |
CN103257935A (zh) | 一种缓存管理方法及其应用 | |
CN107423229B (zh) | 一种面向页级ftl的缓冲区改进方法 | |
CN111580754B (zh) | 一种写友好的闪存固态盘缓存管理方法 | |
CN108845957A (zh) | 一种置换和回写自适应的缓冲区管理方法 | |
CN109783019B (zh) | 一种数据智能存储管理方法与装置 | |
CN107180118A (zh) | 一种文件系统缓存数据管理方法及装置 | |
CN110442382A (zh) | 预取缓存控制方法、装置、芯片以及计算机可读存储介质 | |
CN110321081A (zh) | 一种闪存读缓存的方法及其系统 | |
CN102097128A (zh) | 一种基于闪存的自适应缓冲区置换方法 | |
CN107168652A (zh) | 一种提升SSD Cache读性能的方法 | |
Gu et al. | Dynamic file cache optimization for hybrid SSDs with high-density and low-cost flash memory | |
Wang et al. | LAB-LRU: A Life-Aware Buffer Management Algorithm for NAND Flash Memory | |
JP2002108707A (ja) | キャッシュメモリ制御方式 | |
CN107656879A (zh) | 一种缓存数据的刷写方法、装置及可读存储介质 | |
JPH04220740A (ja) | ファイル制御装置のライトヒット制御方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |