CN107291399A - 一种基于spdk的后端存储方法、装置及系统 - Google Patents
一种基于spdk的后端存储方法、装置及系统 Download PDFInfo
- Publication number
- CN107291399A CN107291399A CN201710520294.4A CN201710520294A CN107291399A CN 107291399 A CN107291399 A CN 107291399A CN 201710520294 A CN201710520294 A CN 201710520294A CN 107291399 A CN107291399 A CN 107291399A
- Authority
- CN
- China
- Prior art keywords
- spdk
- data
- read
- physical block
- nvme disks
- 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
- 238000000034 method Methods 0.000 title claims abstract description 53
- 230000005540 biological transmission Effects 0.000 claims abstract description 13
- 238000012217 deletion Methods 0.000 claims description 7
- 230000037430 deletion Effects 0.000 claims description 7
- 238000011161 development Methods 0.000 description 3
- 238000013500 data storage Methods 0.000 description 2
- CZMRCDWAGMRECN-UGDNZRGBSA-N Sucrose Chemical compound O[C@H]1[C@H](O)[C@@H](CO)O[C@@]1(CO)O[C@@H]1[C@H](O)[C@@H](O)[C@H](O)[C@@H](CO)O1 CZMRCDWAGMRECN-UGDNZRGBSA-N 0.000 description 1
- 229930006000 Sucrose Natural products 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 230000006870 function Effects 0.000 description 1
- 230000002452 interceptive effect Effects 0.000 description 1
- 230000005055 memory storage Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 239000005720 sucrose Substances 0.000 description 1
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/061—Improving I/O performance
- G06F3/0611—Improving I/O performance in relation to response time
-
- 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
-
- 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)
Abstract
本发明实施例公开了一种基于SPDK的后端存储方法、装置及系统,包括接收客户端发送的读写指令;依据读写指令调用SPDK的用户态驱动访问NVMe盘,并对NVMe盘进行相应的读写操作。可见,本发明实施例可以在接收到客户端发送的读写指令后,通过调用SPDK中的用户态驱动直接访问NVMe盘,并对NVMe盘进行相应的读写操作。本发明实施例中采用用户态的方式访问NVMe盘,访问过程中不需要通过本地文件系统,从而减小了IO路径,降低了延时时间,提高了存储系统中软件栈的性能和效率,极大的满足了高性能场景的需求。
Description
技术领域
本发明实施例涉及信息存储技术领域,特别是涉及一种方法、装置及系统。
背景技术
随着科学技术的发展,全闪存储已经成为未来存储的发展趋势。固态存储介质的推出,使存储的吞吐量和延迟性能与传统介质相比更为优良,在整个事务处理所耗时间中,软件部分占用时间的比例大大提升。目前,市场上出现了很多NVMe SSD盘(简称NVMe盘),其中,NVMe是一种建立在M.2接口上的类似AHCI的一种协议,是专门为闪存类存储设计的协议,其目的是统一主流厂商的SSD接口交互标准,并更好地对上层系统释放效率潜能。
现有技术中,在进行数据的读写操作时以内核态的方式访问NVMe盘,采用这种方式访问NVMe盘时,需要通过本地文件系统及驱动才能最终访问NVMe盘,IO路径较长,延时较高,使存储系统中软件栈的性能和效率难以提高,尤其是很难满足高性能场景的需求。
因此,如何提供一种解决上述技术问题的基于SPDK的后端存储方法、装置及系统成为本领域的技术人员需要解决的问题。
发明内容
本发明实施例的目的是提供一种基于SPDK的后端存储方法、装置及系统,在使用过程中减小了IO路径,降低了延时时间,提高了存储系统中软件栈的性能和效率,极大的满足了高性能场景的需求。
为解决上述技术问题,本发明实施例提供了一种基于SPDK的后端存储方法,包括:
接收客户端发送的读写指令;
依据所述读写指令调用SPDK的用户态驱动访问NVMe盘,并对所述NVMe盘进行相应的读写操作。
可选的,所述接收客户端发送的读写指令具体为:
接收客户端发送的写入指令;
所述依据所述读写指令调用SPDK的用户态驱动访问NVMe盘,并对所述NVMe盘进行相应的读写操作的过程具体为:
依据所述写入指令确定待写入数据的第一存储地址,并调用SPDK的用户态驱动访问NVMe盘;
接收待写入数据,并依据预设偏移量和预设长度将所述待写入数据写入所述NVMe盘中与所述第一存储地址相应的物理块中。
可选的,所述依据所述写入指令确定待写入数据的第一存储地址的过程具体为:
依据所述写入指令判断待写入数据所属的数据文件是否为第一次写入,如果是,则从NVMe盘中的所有空闲物理块中找出一个空闲物理块作为待存储物理块,并将所述待存储物理块的存储地址作为待写入数据的第一存储地址;否则,依据所述写入指令从所述NVMe盘中已用物理块中找到与所述数据文件对应的已用物理块,并将所述与数据文件对应的已用物理块的存储地址作为待写入数据的第一存储地址。
可选的,所述接收客户端发送的读写指令具体为:
接收客户端发送的读取指令;
所述依据所述读写指令调用SPDK的用户态驱动访问NVMe盘,并对所述NVMe盘进行相应的读写操作的过程具体为:
依据所述读取指令找到待读取数据的第二存储地址,调用SPDK的用户态驱动并访问所述NVMe盘;
依据预设偏移量和预设长度从所述NVMe盘中与所述第二存储地址相应的物理块中读取相应的数据信息。
可选的,所述方法还包括:
检查所述读写操作是否完成,如果是,则返回完成信息至所述客户端。
可选的,如上述所述的基于SPDK的后端存储方法,所述方法还包括:
接收客户端发送的删除指令;
依据所述删除指令从所述NVMe盘中的所有已用物理块中找到待删除数据对应的已用物理块;
将所述待删除数据对应的已用物理块中的数据进行删除。
为解决上述技术问题,本发明实施例提供了一种基于SPDK的后端存储装置,包括:
接收模块,用于接收客户端发送的读写指令;
访问模块,用于依据所述读写指令调用SPDK的用户态驱动访问NVMe盘,并对所述NVMe盘进行相应的读写操作。
可选的,还包括释放模块;
所述接收模块,还用于接收客户端发送的删除指令;
所述释放模块,用于依据所述删除指令从所述NVMe盘中的所有已用物理块中找到待删除数据对应的已用物理块,并将所述待删除数据对应的已用物理块中的数据进行删除。
可选的,还包括检查模块,用于检查所述读写操作是否完成,如果是,则触发返回模块;
所述返回模块,用于将完成信息返回至所述客户端。
为解决上述技术问题,本发明实施例提供了一种基于SPDK的后端存储系统,包括如上述所述的基于SPDK的后端存储装置。
本发明实施例提供了一种基于SPDK的后端存储方法、装置及系统,包括接收客户端发送的读写指令;依据读写指令调用SPDK的用户态驱动访问NVMe盘,并对NVMe盘进行相应的读写操作。
可见,本发明实施例可以在接收到客户端发送的读写指令后,通过调用SPDK中的用户态驱动直接访问NVMe盘,并对NVMe盘进行相应的读写操作。本发明实施例中采用用户态的方式访问NVMe盘,访问过程中不需要通过本地文件系统,从而减小了IO路径,降低了延时时间,提高了存储系统中软件栈的性能和效率,极大的满足了高性能场景的需求。
附图说明
为了更清楚地说明本发明实施例中的技术方案,下面将对现有技术和实施例中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本发明实施例提供的一种基于SPDK的后端存储方法的流程示意图;
图2为本发明实施例提供的一种基于SPDK的后端存储装置的结构示意图;
图3为本发明实施例提供的另一种基于SPDK的后端存储装置的结构示意图。
具体实施方式
本发明实施例提供了一种基于SPDK的后端存储方法、装置及系统,在使用过程中减小了IO路径,降低了延时时间,提高了存储系统中软件栈的性能和效率,极大的满足了高性能场景的需求。
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
请参照图1,图1为本发明实施例提供的一种基于SPDK的后端存储方法的流程示意图。
该方法包括:
S11:接收客户端发送的读写指令;
S12:依据读写指令调用SPDK的用户态驱动访问NVMe盘,并对NVMe盘进行相应的读写操作。
需要说明的是,SPDK(Storage Performance Development Kit,存储性能开发工具包)可以通过用户态驱动的技术来提升整个存储系统的性能,用户态驱动的方式可以免去内核上下文件切换和中断,从而将节省大量的处理器时间开销,是处理器更集中与处理计算任务。
具体的,在接收到客户端发送的读写指令(读取指令或写入指令)后,可以依据该读写指令调用SPDK的用户态驱动,具体可以通过调用SPDK提供的对外接口来调用其用户态驱动,并通过该用户态驱动直接访问NVMe盘,以进一步对NVMe盘进行相应的读写操作。
进一步的,在上述S11中,接收客户端发送的读写指令具体可以为:
接收客户端发送的写入指令;
则,相应的在S12中依据读写指令调用SPDK的用户态驱动访问NVMe盘,并对NVMe盘进行相应的读写操作的过程,具体可以为:
S121:依据写入指令确定待写入数据的第一存储地址,并调用SPDK的用户态驱动访问NVMe盘;
S122:接收待写入数据,并依据预设偏移量和预设长度将待写入数据写入NVMe盘中与第一存储地址相应的物理块中。
需要说明的是,当接收到的读写指令为写入指令时,可以先为待写入数据选取一个物理块用于存储该待写入数据,也即先确定待写入数据的存储地址,然后再将接收到的待写入数据按照预先设定的偏移量和长度写入至NVMe盘中的与第一存储地址对应的物理块中。
具体的,本发明实施例中可以通过InspurAllocator(分配)模块将NVMe盘中用于存储数据信息的各个物理块进行分配,例如当需要写入数据时,则首先需要选出一个物理块用于存储写入的数据信息,并且当数据信息写入完成后,可以将物理块的编号与所存储的数据信息的标识码等信息记录至分配记录中,并且将该分配记录存储至数据库中,例如可以存储至RocksDB数据库中,以便下次需要对已经写入的文件进行修改或者补充时,可以根据该分配记录找到存储该文件的物理块,从而对该文件进行修改或补充的操作。
另外,由于RocksDB数据库是一种键值数据库的实现,是Facebook在Level数据库进行改进得到的产物,具备较高的存储效率,所以本发明实施例中优选的将分配记录存储至RocksDB数据库中。
更进一步的,依据写入指令确定待写入数据的第一存储地址的过程具体为:
依据写入指令判断待写入数据所属的数据文件是否为第一次写入,如果是,则从NVMe盘中的所有空闲物理块中找出一个空闲物理块作为待存储物理块,并将待存储物理块的存储地址作为待写入数据的第一存储地址;否则,依据写入指令从NVMe盘中已用物理块中找到与数据文件对应的已用物理块,并将与数据文件对应的已用物理块的存储地址作为待写入数据的第一存储地址。
可以理解的是,如果某个数据文件在写入的过程中中断了,则再次对该数据文件进行数据写入时,需要找到与该数据文件对应的物理块,并将相应的待写入数据存储至该物理块中,以实现对相应的数据文件的继续写入。
具体的,写入指令中可以包括待写入数据的大小和待写入数据所属数据文件的名称等信息,则系统在接收到写入指令后,可以根据该写入指令判断待写入数据所归属的数据文件是否已经存储在NVMe盘中的某个或某几个物理块中,具体可以通过分配记录进行查找,如果该待写入数据所属的数据文件已经存储在某个已用物理块中,则获取相应的已用物理块的存储地址(也即第一存储地址),从而可以将接收到的待写入数据按照预设偏移量和预设长度写入至第一存储地址对应的物理块中;如果该待写入数据所属的数据文件时第一次写入,则可以从所有的空闲物理块中选出一个空闲物理块并获取该空闲物理块的地址,从而可以将接收到的待写入数据按照预设偏移量和预设长度写入至相应的空闲物理块中,此时该空闲物理块将成为已用物理块,并且还可以将该已用物理块的相关信息记录至分配记录中。
需要说明的是,NVMe盘中的各个空闲物理块的信息存储至RocksDB数据库中,可以通过RocksDB数据库中查找各个空闲物理块的信息,从而选出一个空闲物理块用于存储待写入数据。
具体的,在上述S11中,接收客户端发送的读写指令具体可以为:
接收客户端发送的读取指令;
则,相应的在S12中,依据读写指令调用SPDK的用户态驱动访问NVMe盘,并对NVMe盘进行相应的读写操作的过程,具体可以为:
S123:依据读取指令找到待读取数据的第二存储地址,并调用SPDK的用户态驱动访问NVMe盘;
S124:依据预设偏移量和预设长度从NVMe盘中与第二存储地址相应的物理块中读取相应的数据信息。
可以理解的是,当接收到的读写指令为读取指令时,可以根据该读取指令中的具体信息从RocksDB数据库中的分配记录中找到与待读取数据对应的已用物理块的存储地址(及第二存储地址),并通过调用SPDK的用户态驱动访问NVMe盘,从与第二存储地址对应的已用物理块中读取待读取数据,具体可以按照预设偏移量和预设长度对待读取数据进行读取。
可选的,该方法还包括:
S13:检查读写操作是否完成,如果是,则返回完成信息至客户端。
具体的,可以通过aio_thread线程检查相应的读写操作是否完成(检查aio是否完成),如果相应的读写操作完成,则可以调用回调函数io_completion通知客户端。
需要说明的是,采用aio_thread线程可以不需要等待当前数据信息写入或读取完成后再进行下一个数据信息的写入或读取,可以对多个数据信息进行并行写入或读取,提高了数据信息的读写效率。
可选的,如上述的基于SPDK的后端存储方法,该方法还可以包括:
S14:接收客户端发送的删除指令;
S15:依据删除指令从NVMe盘中的所有已用物理块中找到待删除数据对应的已用物理块;
S16:将待删除数据对应的已用物理块中的数据进行删除。
可以理解的是,当某些数据信息需要删除时,还可以根据客户端发送的删除指令找到待删除数据所在的已用物理块,并将该物理块中的待删除数据进行删除,已完成对该已用物理块的释放,从而该物理块成为空闲物理块,可以将该空闲物理块的空闲信息添加至RocksDB数据库中进行保存,当再次有数据写入时,可以从RocksDB数据库中所存储的空闲物理块的空闲信息中选择出相应的物理块及获取其存储地址,以便进行相应数据信息的写入。
还需要说明的是,本发明实施例在使用过程中还可以自行管理磁盘空间的分配、使用和释放等工作,在一定程度上缩短了IO栈流程,提高了性能。
本发明实施例提供了一种基于SPDK的后端存储方法,包括接收客户端发送的读写指令;依据读写指令调用SPDK的用户态驱动访问NVMe盘,并对NVMe盘进行相应的读写操作。
可见,本发明实施例可以在接收到客户端发送的读写指令后,通过调用SPDK中的用户态驱动直接访问NVMe盘,并对NVMe盘进行相应的读写操作。本发明实施例中采用用户态的方式访问NVMe盘,访问过程中不需要通过本地文件系统,从而减小了IO路径,降低了延时时间,提高了存储系统中软件栈的性能和效率,极大的满足了高性能场景的需求。
相应的本发明实施例还公开了一种基于SPDK的后端存储装置,具体请参照图2,图2为本发明实施例提供的一种基于SPDK的后端存储装置的结构示意图。在上述实施例的基础上:
该装置包括:
接收模块1,用于接收客户端发送的读写指令;
访问模块2,用于依据读写指令调用SPDK的用户态驱动访问NVMe盘,并对NVMe盘进行相应的读写操作。
可见,本发明实施例可以在接收到客户端发送的读写指令后,通过调用SPDK中的用户态驱动直接访问NVMe盘,并对NVMe盘进行相应的读写操作。本发明实施例中采用用户态的方式访问NVMe盘,访问过程中不需要通过本地文件系统,从而减小了IO路径,降低了延时时间,提高了存储系统中软件栈的性能和效率,极大的满足了高性能场景的需求。
另外,对于本发明实施例中涉及到的基于SPDK的后端存储方法的具体介绍请参照上述方法实施例,本申请在此不再赘述。
请参照图3,图3为本发明实施例提供的另一种基于SPDK的后端存储装置的结构示意图。在上述实施例的基础上:
可选的,该装置还包括释放模块;
接收模块1,还用于接收客户端发送的删除指令;
释放模块3,用于依据删除指令从NVMe盘中的所有已用物理块中找到待删除数据对应的已用物理块,并将待删除数据对应的已用物理块中的数据进行删除。
可选的,还包括检查模块4,用于检查读写操作是否完成,如果是,则触发返回模块5;
返回模块5,用于将完成信息返回至客户端。
本发明实施例在使用过程中减小了IO路径,降低了延时时间,提高了存储系统中软件栈的性能和效率,极大的满足了高性能场景的需求。
另外,对于本发明实施例中涉及到的基于SPDK的后端存储方法的具体介绍请参照上述方法实施例,本申请在此不再赘述。
在上述实施例的基础上,本发明实施例提供了一种基于SPDK的后端存储系统,包括如上述的基于SPDK的后端存储装置。
需要说明的是,本发明实施例可以在接收到客户端发送的读写指令后,通过调用SPDK中的用户态驱动直接访问NVMe盘,并对NVMe盘进行相应的读写操作。本发明实施例中采用用户态的方式访问NVMe盘,访问过程中不需要通过本地文件系统,从而减小了IO路径,降低了延时时间,提高了存储系统中软件栈的性能和效率,极大的满足了高性能场景的需求。此外,对于本发明实施例中涉及到的基于SPDK的后端存储方法的具体介绍请参照上述方法实施例,本申请在此不再赘述。
还需要说明的是,在本说明书中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
对所公开的实施例的上述说明,使本领域专业技术人员能够实现或使用本发明。对这些实施例的多种修改对本领域的专业技术人员来说将是显而易见的,本文中所定义的一般原理可以在不脱离本发明的精神或范围的情况下,在其他实施例中实现。因此,本发明将不会被限制于本文所示的这些实施例,而是要符合与本文所公开的原理和新颖特点相一致的最宽的范围。
Claims (10)
1.一种基于SPDK的后端存储方法,其特征在于,包括:
接收客户端发送的读写指令;
依据所述读写指令调用SPDK的用户态驱动访问NVMe盘,并对所述NVMe盘进行相应的读写操作。
2.根据权利要求1所述的基于SPDK的后端存储方法,其特征在于,所述接收客户端发送的读写指令具体为:
接收客户端发送的写入指令;
所述依据所述读写指令调用SPDK的用户态驱动访问NVMe盘,并对所述NVMe盘进行相应的读写操作的过程具体为:
依据所述写入指令确定待写入数据的第一存储地址,并调用SPDK的用户态驱动访问NVMe盘;
接收待写入数据,并依据预设偏移量和预设长度将所述待写入数据写入所述NVMe盘中与所述第一存储地址相应的物理块中。
3.根据权利要求2所述的基于SPDK的后端存储方法,其特征在于,所述依据所述写入指令确定待写入数据的第一存储地址的过程具体为:
依据所述写入指令判断待写入数据所属的数据文件是否为第一次写入,如果是,则从NVMe盘中的所有空闲物理块中找出一个空闲物理块作为待存储物理块,并将所述待存储物理块的存储地址作为待写入数据的第一存储地址;否则,依据所述写入指令从所述NVMe盘中已用物理块中找到与所述数据文件对应的已用物理块,并将所述与数据文件对应的已用物理块的存储地址作为待写入数据的第一存储地址。
4.根据权利要求2所述的基于SPDK的后端存储方法,其特征在于,所述接收客户端发送的读写指令具体为:
接收客户端发送的读取指令;
所述依据所述读写指令调用SPDK的用户态驱动访问NVMe盘,并对所述NVMe盘进行相应的读写操作的过程具体为:
依据所述读取指令找到待读取数据的第二存储地址,并调用SPDK的用户态驱动访问所述NVMe盘;
依据预设偏移量和预设长度从所述NVMe盘中与所述第二存储地址相应的物理块中读取相应的数据信息。
5.根据权利要求1所述的基于SPDK的后端存储方法,其特征在于,所述方法还包括:
检查所述读写操作是否完成,如果是,则返回完成信息至所述客户端。
6.根据权利要求1-5任意一项所述的基于SPDK的后端存储方法,其特征在于,所述方法还包括:
接收客户端发送的删除指令;
依据所述删除指令从所述NVMe盘中的所有已用物理块中找到待删除数据对应的已用物理块;
将所述待删除数据对应的已用物理块中的数据进行删除。
7.一种基于SPDK的后端存储装置,其特征在于,包括:
接收模块,用于接收客户端发送的读写指令;
访问模块,用于依据所述读写指令调用SPDK的用户态驱动访问NVMe盘,并对所述NVMe盘进行相应的读写操作。
8.根据权利要求7所述的基于SPDK的后端存储装置,其特征在于,还包括释放模块;
所述接收模块,还用于接收客户端发送的删除指令;
所述释放模块,用于依据所述删除指令从所述NVMe盘中的所有已用物理块中找到待删除数据对应的已用物理块,并将所述待删除数据对应的已用物理块中的数据进行删除。
9.根据权利要求8所述的基于SPDK的后端存储装置,其特征在于,还包括检查模块,用于检查所述读写操作是否完成,如果是,则触发返回模块;
所述返回模块,用于将完成信息返回至所述客户端。
10.一种基于SPDK的后端存储系统,其特征在于,包括如权利要求7-9任意一项所述的基于SPDK的后端存储装置。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710520294.4A CN107291399B (zh) | 2017-06-30 | 2017-06-30 | 一种基于spdk的后端存储方法、装置及系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710520294.4A CN107291399B (zh) | 2017-06-30 | 2017-06-30 | 一种基于spdk的后端存储方法、装置及系统 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN107291399A true CN107291399A (zh) | 2017-10-24 |
CN107291399B CN107291399B (zh) | 2020-11-24 |
Family
ID=60099065
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201710520294.4A Active CN107291399B (zh) | 2017-06-30 | 2017-06-30 | 一种基于spdk的后端存储方法、装置及系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN107291399B (zh) |
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109213772A (zh) * | 2018-09-12 | 2019-01-15 | 华东师范大学 | 数据存储方法及NVMe存储系统 |
CN111008233A (zh) * | 2019-11-24 | 2020-04-14 | 浪潮电子信息产业股份有限公司 | 一种kv数据库的访问方法、装置及设备 |
CN111190548A (zh) * | 2019-12-30 | 2020-05-22 | 创新科技术有限公司 | 一种基于SPDK的ceph分布式存储性能提升方法、装置及设备 |
CN112347044A (zh) * | 2020-11-10 | 2021-02-09 | 北京赛思信安技术股份有限公司 | 一种基于spdk的对象存储优化方法 |
CN113821393A (zh) * | 2021-09-26 | 2021-12-21 | 储鹤 | 一种NVMe固态硬盘测试模块及测试方法 |
CN114138200A (zh) * | 2021-12-01 | 2022-03-04 | 浪潮云信息技术股份公司 | 一种基于RocksDB的预写日志方法及系统 |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1602490A (zh) * | 2001-12-11 | 2005-03-30 | 汤姆森许可贸易公司 | 存储设备 |
CN101634936A (zh) * | 2008-07-23 | 2010-01-27 | 深圳市中深瑞泰科技有限公司 | 通过fpga实现arm架构处理器与硬盘之间接口的方法 |
CN102014158A (zh) * | 2010-11-29 | 2011-04-13 | 北京兴宇中科科技开发股份有限公司 | 一种云存储服务客户端高效细粒度数据缓存系统与方法 |
CN104571963A (zh) * | 2014-12-31 | 2015-04-29 | 曙光信息产业股份有限公司 | Raid的元数据的处理方法和装置 |
CN104615383A (zh) * | 2015-02-06 | 2015-05-13 | 安一恒通(北京)科技有限公司 | 一种基于虚拟磁盘的软件运行方法及装置 |
CN106155758A (zh) * | 2015-03-24 | 2016-11-23 | 联想(北京)有限公司 | 一种服务器系统及其相关控制方法 |
US20170123673A1 (en) * | 2010-02-10 | 2017-05-04 | Kabushiki Kaisha Toshiba | Memory system |
-
2017
- 2017-06-30 CN CN201710520294.4A patent/CN107291399B/zh active Active
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1602490A (zh) * | 2001-12-11 | 2005-03-30 | 汤姆森许可贸易公司 | 存储设备 |
CN101634936A (zh) * | 2008-07-23 | 2010-01-27 | 深圳市中深瑞泰科技有限公司 | 通过fpga实现arm架构处理器与硬盘之间接口的方法 |
US20170123673A1 (en) * | 2010-02-10 | 2017-05-04 | Kabushiki Kaisha Toshiba | Memory system |
CN102014158A (zh) * | 2010-11-29 | 2011-04-13 | 北京兴宇中科科技开发股份有限公司 | 一种云存储服务客户端高效细粒度数据缓存系统与方法 |
CN104571963A (zh) * | 2014-12-31 | 2015-04-29 | 曙光信息产业股份有限公司 | Raid的元数据的处理方法和装置 |
CN104615383A (zh) * | 2015-02-06 | 2015-05-13 | 安一恒通(北京)科技有限公司 | 一种基于虚拟磁盘的软件运行方法及装置 |
CN106155758A (zh) * | 2015-03-24 | 2016-11-23 | 联想(北京)有限公司 | 一种服务器系统及其相关控制方法 |
Cited By (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109213772A (zh) * | 2018-09-12 | 2019-01-15 | 华东师范大学 | 数据存储方法及NVMe存储系统 |
CN111008233A (zh) * | 2019-11-24 | 2020-04-14 | 浪潮电子信息产业股份有限公司 | 一种kv数据库的访问方法、装置及设备 |
CN111008233B (zh) * | 2019-11-24 | 2023-02-28 | 浪潮电子信息产业股份有限公司 | 一种kv数据库的访问方法、装置及设备 |
CN111190548A (zh) * | 2019-12-30 | 2020-05-22 | 创新科技术有限公司 | 一种基于SPDK的ceph分布式存储性能提升方法、装置及设备 |
CN111190548B (zh) * | 2019-12-30 | 2023-09-22 | 创新科技术有限公司 | 一种基于SPDK的ceph分布式存储性能提升方法、装置及设备 |
CN112347044A (zh) * | 2020-11-10 | 2021-02-09 | 北京赛思信安技术股份有限公司 | 一种基于spdk的对象存储优化方法 |
CN112347044B (zh) * | 2020-11-10 | 2024-04-12 | 北京赛思信安技术股份有限公司 | 一种基于spdk的对象存储优化方法 |
CN113821393A (zh) * | 2021-09-26 | 2021-12-21 | 储鹤 | 一种NVMe固态硬盘测试模块及测试方法 |
CN113821393B (zh) * | 2021-09-26 | 2024-01-23 | 储鹤 | 一种NVMe固态硬盘测试模块及测试方法 |
CN114138200A (zh) * | 2021-12-01 | 2022-03-04 | 浪潮云信息技术股份公司 | 一种基于RocksDB的预写日志方法及系统 |
CN114138200B (zh) * | 2021-12-01 | 2023-10-13 | 上海沄熹科技有限公司 | 一种基于RocksDB的预写日志方法及系统 |
Also Published As
Publication number | Publication date |
---|---|
CN107291399B (zh) | 2020-11-24 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN107291399A (zh) | 一种基于spdk的后端存储方法、装置及系统 | |
CN109977111A (zh) | 采用基于散列和基于树的键-值数据结构的数据管理系统 | |
US20120079168A1 (en) | Method for performing block management, and associated memory device and controller thereof | |
US20050015557A1 (en) | Nonvolatile memory unit with specific cache | |
CN109923530A (zh) | 混合式存储器中的数据重新定位 | |
CN106708427A (zh) | 一种适用于键值对数据的存储方法 | |
CN105683953B (zh) | 支持加速数据库操作的数据存储设备 | |
WO2001055857A3 (en) | Logical view and access to data managed by a modular data and storage management system | |
RU2010130774A (ru) | Способ выбора множества ячеек памяти (варианты) | |
US9274865B2 (en) | Implementing enhanced buffer management for data storage devices | |
CN110399310A (zh) | 一种存储空间的回收方法及装置 | |
CN109144411A (zh) | 数据中心混合磁盘阵列及其数据动态迁移策略 | |
CN106970765A (zh) | 数据存储方法及装置 | |
CN103473298A (zh) | 数据归档方法和装置以及存储系统 | |
CN107817945A (zh) | 一种混合内存结构的数据读取方法和系统 | |
CN107168651A (zh) | 一种小文件聚合存储处理方法 | |
CN109271110A (zh) | 存储系统中存储数据的写入方法、写入系统及相关装置 | |
CN102024060B (zh) | 存储文件及恢复误删除文件的方法 | |
CN108153495A (zh) | 数据存储方法、装置及数据存储系统 | |
US20120137107A1 (en) | Method of decaying hot data | |
CN101197177A (zh) | 新型智能磁带机及其数据处理方法 | |
US6876579B2 (en) | Method writing data to a large block of a flash memory cell | |
CN105654972A (zh) | 一种面向可交换光盘匣光盘库快速自检方法及装置 | |
CN106055269A (zh) | 硬驱动器中的界域分区 | |
CN108646987A (zh) | 一种文件卷的管理方法、装置、存储介质及终端 |
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 | ||
TA01 | Transfer of patent application right | ||
TA01 | Transfer of patent application right |
Effective date of registration: 20201105 Address after: 215100 No. 1 Guanpu Road, Guoxiang Street, Wuzhong Economic Development Zone, Suzhou City, Jiangsu Province Applicant after: SUZHOU LANGCHAO INTELLIGENT TECHNOLOGY Co.,Ltd. Address before: 450018 Henan province Zheng Dong New District of Zhengzhou City Xinyi Road No. 278 16 floor room 1601 Applicant before: ZHENGZHOU YUNHAI INFORMATION TECHNOLOGY Co.,Ltd. |
|
GR01 | Patent grant | ||
GR01 | Patent grant |