CN115599290A - 键值固态驱动器中的动态存储 - Google Patents

键值固态驱动器中的动态存储 Download PDF

Info

Publication number
CN115599290A
CN115599290A CN202210773955.5A CN202210773955A CN115599290A CN 115599290 A CN115599290 A CN 115599290A CN 202210773955 A CN202210773955 A CN 202210773955A CN 115599290 A CN115599290 A CN 115599290A
Authority
CN
China
Prior art keywords
key
node
region
keys
metadata
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.)
Pending
Application number
CN202210773955.5A
Other languages
English (en)
Inventor
S.T.希瓦南德
K.加格
保尔.贾斯汀.K
S.C.雷迪
S.G.克姆斯
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Samsung Electronics Co Ltd
Original Assignee
Samsung Electronics Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Samsung Electronics Co Ltd filed Critical Samsung Electronics Co Ltd
Publication of CN115599290A publication Critical patent/CN115599290A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0638Organizing or formatting or addressing of data
    • G06F3/0644Management of space entities, e.g. partitions, extents, pools
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0608Saving storage space on storage systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0604Improving or facilitating administration, e.g. storage management
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0629Configuration or reconfiguration of storage systems
    • G06F3/0631Configuration or reconfiguration of storage systems by allocating resources to storage systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0638Organizing or formatting or addressing of data
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0638Organizing or formatting or addressing of data
    • G06F3/064Management of blocks
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0673Single storage device
    • G06F3/0679Non-volatile semiconductor memory device, e.g. flash memory, one time programmable memory [OTP]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0638Organizing or formatting or addressing of data
    • G06F3/0643Management of files

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

一种用于动态存储键和值的方法包括接收将一个或多个键存储在键值固态驱动器(KV‑SSD)中的请求。该方法还包括执行用于将一个或多个键中的每个键存储在KV‑SSD的数据结构的节点中的存储操作。存储操作包括在节点中分配第一区域用于存储键,使得第一区域的大小等于键的大小。存储操作还包括在节点中分配第二区域用于存储与键相关联的键元数据,使得第二区域具有预定大小。存储操作还包括将键存储在节点的第一区域中,并将键元数据存储在节点的第二区域中。

Description

键值固态驱动器中的动态存储
相关申请的交叉引用
本申请要求于2021年7月7日提交的第202141030420号印度专利申请的优先权,其公开内容通过引用整体并入本文。
技术领域
本公开一般涉及将键(key)存储在存储装置/存储器中,尤其涉及将键存储在键值固态驱动器中。
背景技术
键值固态驱动器(KV SSD)支持在其中存储键值数据。键值数据通常包括一个或多个键以及与这些键相关联的值。在示例中,当存储在KV SSD中时,键存储在KV SSD中实施的给定数据结构的节点中。许多不同的已知数据结构可以用于实施KV SSD中的键和值的存储。
在一些实施B+树数据结构的KV SSD中,用于在给定节点中存储键的技术涉及将每个键存储在节点的对应区域中。节点中的该区域或空间具有预定的固定大小。有时,这种存储模式会导致节点中浪费的存储空间。例如,考虑这样的示例,其中预定大小是256字节,要存储的键的大小是8字节。在这种情况下,256个可用字节中的大部分将不会被使用。
在本领域中需要提供一种具有增加的空间利用率的存储模式。
发明内容
提供以下概述以介绍一些概念,这些概念将在本文所包括的详细描述中进一步描述。该概述不旨在标识关键或必要的发明概念,也不旨在用于确定本发明的范围。
在被配置为存储键值对的***的一些比较示例中使用的存储模式可能导致浪费的空间。例如,在实施B+树数据结构的KV SSD中,可以为每个键分配256字节的键空间。然而,键通常不具有一致的大小。键可以是例如7字节、8字节、128字节等;即,具有比分配的空间更小的大小。本公开提供了用于有效存储键值对的方法的实施例。在实施例中,该方法从存储器节点的一端用键来填充节点,并且从节点的另一端填充关于键的元数据。键和它们的元数据朝向中心汇聚。本文描述的(多个)方法提供了一种最大限度地利用节点中的可用空间的方式。
在实施例中,公开了一种方法。该方法包括接收将一个或多个键存储在键值固态驱动器(KV-SSD)中的请求。该方法还包括执行用于将一个或多个键中的每个键存储在KV-SSD的数据结构的节点中的存储操作。对于一个或多个键中的每个键,存储操作包括在节点中分配第一区域用于存储键,使得第一区域的大小等于键的大小。存储操作还包括在节点中分配第二区域用于存储与键相关联的键元数据,使得第二区域具有预定大小。此外,存储操作包括将键存储在节点的第一区域中,并将键元数据存储在节点的第二区域中。
在另一实施例中,公开了一种***。该***包括请求处理器,被配置为接收将多个键存储在键值固态驱动器(KV-SSD)中的请求。该***还包括存储器管理器,被配置为执行用于将多个键中的每个键存储在KV-SSD的数据结构的节点中的存储操作。在存储操作中,存储器管理器被配置为在节点中分配第一区域用于存储键,使得第一区域的大小等于键的大小。此外,存储器管理器被配置为在节点中分配第二区域用于存储与键相关联的键元数据,使得第二区域具有预定大小。此外,存储器管理器被配置为将键存储在节点的第一区域中,并将键元数据存储在节点的第二区域中。
为了进一步阐明本发明概念的特征,将通过参考在附图中示出的本发明的具体实施例来对本发明进行更具体的描述。应当理解,这些附图描绘了本发明的示例实施例,因此不应被认为是对其范围的限制。将结合附图以额外的特征和细节来描述和解释本发明概念。
附图说明
通过参考附图详细描述本公开的示例实施例,本公开的上述和其他方面和特征将变得更加明显,在附图中:
图1示出了根据本公开的实施例的实施用于将键存储在键值固态驱动器(KV SSD)中的***的网络环境;
图2示出了根据本公开的实施例的将键存储在KV SSD中的方法;
图3示出了根据本公开的实施例的节点的分段过程;
图4示出了根据本公开的实施例的节点的结构;并且
图5示出了根据本公开的实施例的比较结果。
应当理解,附图中的元件是为了简单起见而示出的,可能不一定是按比例绘制的。例如,流程图根据所涉及的最显著的步骤示出了方法的实施例,以帮助提高对本发明概念的各方面的理解。此外,就设备的构造而言,设备的一个或多个组件可能已经在附图中由常规符号表示,并且附图可能仅示出与理解本发明概念的实施例相关的那些具体细节,以便不会用受益于本文描述的本领域普通技术人员将容易明白的细节来模糊附图。
具体实施方式
为了促进对本发明概念的原理的理解,现在将参考附图中示出的实施例,并且将使用特定的语言来描述这些实施例。应当理解,这并不意味着对本发明概念的范围的限制,并且在不实质上背离本发明概念的范围的情况下,可以进行对示出的***的变更和修改以及对示出的本发明概念的原理的进一步应用。
本领域技术人员将理解,前面的一般描述和下面的详细描述是对本发明概念的解释,而不是对本发明概念的限制。
贯穿本说明书对“一个方面”、“另一方面”或类似语言的引用可能意味着结合该实施例描述的特定特征、结构或特性被包括在本发明概念的至少一个实施例中。因此,贯穿本说明书出现的短语“在实施例中”、“在另一实施例中”和类似的语言可以但不一定都指同一实施例。
术语“包括”、“包含”或其任何其他变体旨在涵盖非排他性的包含,使得包括一系列步骤的过程或方法不仅包括那些步骤,还可以包括未明确列出的或该过程或方法固有的其他步骤。类似地,以“包含…”或“包括…”开头的一个或多个设备或子***或元件或结构或组件在没有更多限制的情况下,不排除其他设备或其他子***或其他元件或其他结构或其他组件或附加设备或附加子***或附加元件或附加结构或附加组件的存在。
除非另有定义,否则本文使用的所有技术和科学术语具有与本发明概念所属领域的普通技术人员通常理解的相同含义。本文提供的***、方法和示例仅是说明性的,而不是限制性的。
下面将参考附图详细描述本发明概念的实施例。
图1示出了根据本公开的一个或多个实施例的包括***102的环境100。环境100还示出了键值(KV)固态驱动器(KV SSD)104和一个或多个KV应用106。在示例中,***102可以被配置为将与KV应用106有关的多个键存储在KV SSD 104中。***102可以在例如计算设备(诸如数据服务器、服务器、数据存储、膝上型电脑、台式电脑等)中实施。
在示例中,***102包括处理器110、存储器112、请求处理器114、存储器管理器116、查询处理器118和数据120。在示例中,存储器112、请求处理器114、存储器管理器116和查询处理器118耦接到处理器110。处理器110可以是单个处理单元或多个单元,所有这些单元都可以包括多个计算单元。处理器110可以被实施为一个或多个微处理器、微型计算机、微控制器、数字信号处理器、中央处理单元、状态机、逻辑电路和/或基于操作指令操纵信号的任何设备。处理器110被配置用于多种功能,包括获取和执行存储在存储器112中的计算机可读指令和数据的能力。
存储器112可以包括非暂时性计算机可读介质,包括例如易失性存储器,诸如静态随机存取存储器(SRAM)和动态随机存取存储器(DRAM),和/或非易失性存储器,诸如只读存储器(ROM)、可擦除可编程ROM、闪存、硬盘、光盘和磁带。
请求处理器114、存储器管理器116和查询处理器118等包括可以执行特定任务或实施数据类型的例程、程序、对象、组件、数据结构等。请求处理器114、存储器管理器116和查询处理器118也可以被实施为例如(多个)信号处理器、(多个)状态机、逻辑电路和/或基于操作指令操纵信号的任何其他设备或组件。此外,请求处理器114、存储器管理器116和查询处理器118可以用硬件、由处理单元执行的指令或其组合来实施。处理单元可以是或包括计算机、处理器(诸如处理器110)、状态机、逻辑阵列或能够处理指令的任何其他合适的设备。处理单元可以是通用处理器,其被配置为执行指令以使通用处理器执行所需的任务,或者处理单元可以专用于执行所需的功能。
在本公开的一些实施例中,请求处理器114、存储器管理器116和查询处理器118可以是机器可读指令(软件),当由处理器/处理单元执行时,该机器可读指令(软件)执行任何所描述的功能。数据120用作储存库等,用于存储由处理器110、请求处理器114、存储器管理器116或查询处理器118处理、接收和生成的数据。
在示例中,KV应用106被配置为在它们各自的操作期间管理、生成、更新或删除KV数据等。KV数据可以包括键值对。关于前述操作,KV应用106可以向***102做出对应的请求。例如,在示例实施例中,为了将键108存储在KV SSD 104中,KV应用106可以向***102做出存储请求。
在示例实施例中,请求处理器114可以被配置为接收将多个键108存储在KV SSD104中的存储请求。在示例中,请求处理器114可以将存储请求存储在数据120中。在示例中,存储请求可以包括要存储在KV SSD 104中的键108。在示例中,存储请求可以包括到***102可以从其获得要存储在KV SSD 104中的键108的存储装置的链接或路径。
因此,在示例实施例中,存储器管理器116可以被配置为从存储请求和/或从其中提供的链接/路径获得键108。换句话说,存储器管理器116可以基于存储请求获得键108。
在示例实施例中,存储器管理器116可以被配置为执行可以将多个键108中的每个键存储在KV SSD 104的数据结构的节点中的存储操作。以下描述适用于参考图4的实施例,其中图4示出了KV SSD 104的数据结构的节点400。
在示例实施例中,节点400至少包括键区域402和键元数据区域404。在示例中,存储器管理器116可以将多个键108存储在键区域402中。此外,存储器管理器116可以将与多个键108中的每一个相关联的键元数据存储在键元数据区域404中。在示例实施例中,与键108相关联的键元数据可以包括与键108相关联的偏移值和键108的大小。在示例中,偏移值指示节点400中的键108的位置。在示例实施例中,键区域402从节点400的第一端406开始,键元数据区域404从节点400的第二端408开始。此外,在示例实施例中,第二端408可以与第一端406相对。
此外,在示例实施例中,节点400还包括位于键区域和键元数据区域之间的安全区域410。安全区域410可以被理解为存在于节点400中的预定大小的区域,其防止键区域402和键元数据区域404之间的重叠。此外,在示例实施例中,节点400还包括节点元数据区域412。节点元数据区域412包括关于节点400的占用率的信息。
以下描述适用于仅参考一个键108的存储操作。可以理解,多个键108中的其他键可以以类似的方式存储。
在示例实施例中,在存储操作中,存储器管理器116可以被配置为在节点400中分配第一区域414。可以分配第一区域414,使得第一区域414的大小等于键108的大小。此后,存储器管理器116可以被配置为在节点400中分配第二区域416,用于存储与键108相关联的键元数据。可以分配第二区域416,使得第二区域416具有预定大小。在示例实施例中,第二区域416的预定大小是3字节。
在示例实施例中,一旦存储器管理器116已经分配了第一区域414和第二区域416,存储器管理器116然后可以将键存储在第一区域414中,并将键元数据存储在第二区域416中。
在示例实施例中,存储器管理器116可以被配置为从节点400的第一端406开始将多个键108存储在键区域402中。在实施例中,存储器管理器116可以被配置为从节点400的第二端408开始存储与键108中的每一个相关联的键元数据。
根据本公开的各方面,存储器管理器116从节点的一端存储多个键108并且从节点的另一端存储对应的键元数据。键108中的每一个的键元数据有助于保持顺序并跟踪节点中的可用空间。根据上述方面,键108占用所需的确切空间,并且对应的键元数据是恒定的,并且驻留在节点的另一端。因此,对于不同的工作负载,动态顺序确保节点内的最大键空间利用率。
在示例中,KV应用106可以发送删除多个键108中的至少一个键的请求。在示例实施例中,请求处理器114可以从KV应用106接收请求。在示例中,响应于接收到请求,存储器管理器116可以被配置为从节点400删除至少一个键和相关联的元数据。
在示例实施例中,存储器管理器116可以被配置为在节点400上执行分段过程。在分段过程中,存储器管理器116可以被配置为更新键区域402中的多个键108中的一个或多个键的位置。例如,分段过程可以涉及对节点400的一个或多个部分进行去分段的过程。因此,存储器管理器116可以被配置为基于一个或多个键中的每一个的新位置来更新与多个键108中的一个或多个键相关联的对应的键元数据。
在示例实施例中,请求处理器114可以被配置为接收在节点400中存储另一键的进一步请求。在示例实施例中,存储器管理器116可以被配置为确定下一个键的大小是否大于节点中的可用空间。为此,在示例中,存储器管理器116可以基于节点元数据区域412来确定可用空间。随后,存储器管理器116可以将可用空间与下一个键的大小进行比较。在示例中,如果确定下一个键的大小大于可用空间,则存储器管理器116可以被配置为执行分段过程,如上所述。在执行分段过程之后,存储器管理器116可以再次确定可用空间,并将其与下一个键的大小进行比较。如果下一个键的大小现在被确定为小于可用空间,存储器管理器116可以被配置为将下一个键存储在节点400中。在另一示例中,如果下一个键的大小仍然大于可用空间,则存储器管理器116可以取消下一个键的存储过程,并且可以通知KV应用106。
在示例实施例中,请求处理器114可以被配置为从KV应用106接收范围查询调用。查询处理器118可以被配置为基于键元数据区域404来服务范围查询调用。在范围查询调用的服务期间,查询处理器118可以被配置为对键元数据区域404执行二分搜索。在本文中,在二分搜索中,查询处理器118寻找由键元数据表示的键。
图2示出了根据本公开的实施例的将键存储在KV SSD中的方法200。方法200可以使用***102的一个或多个组件来实施。在下面的描述中可以省略已经参考上面图1和图4的描述详细解释的组件的重复描述。
在步骤202,接收将多个键存储在KV SSD中的请求。在示例中,存储键的请求可以由KV应用(诸如KV应用106)发送。在示例中,请求处理器114可以从KV应用106接收存储请求。
在步骤204,执行用于将多个键中的每个键存储在KV SSD的数据结构的节点中的存储操作。在示例中,存储器管理器116可以执行存储操作。在示例中,节点至少包括键区域和键元数据区域。键区域存储多个键,并且键元数据区域存储与多个键中的每一个相关联的键元数据。此外,键区域从节点的第一端开始,并且键元数据区域从节点的第二端开始。在示例中,第二端与第一端相对。
此外,在示例中,节点还包括位于键区域和键元数据区域之间的安全区域。此外,在示例实施例中,节点还包括节点元数据区域,其中该节点元数据区域包括关于节点的占用率的信息。
返回参考存储操作,存储操作包括如下所述的各种步骤。
在存储操作的步骤204-a,节点中的第一区域被分配用于存储键,使得第一区域的大小等于键的大小。
在存储操作的步骤204-b,节点中的第二区域被分配用于存储与键相关联的键元数据,使得第二区域具有预定大小。在示例中,第二区域可以具有3字节的大小。
在存储操作的步骤204-c,键存储在节点的第一区域中,并且键元数据存储在节点的第二区域中。
在示例实施例中,方法200还包括从节点的第一端开始将多个键存储在键区域中。例如,参考图4,第一键可以存储在节点400的第一端406处或附近,并且要存储的下一个键可以存储在第一键附近,等等。此外,在示例实施例中,方法200还包括以类似的方式从节点的第二端开始将与多个键中的每一个相关联的键元数据存储在键元数据区域中。
在示例实施例中,方法200还包括从KV应用接收范围查询调用。在示例实施例中,方法200还包括基于键元数据区域来服务范围查询调用。
在示例实施例中,方法200还包括接收从多个键中删除至少一个键的请求。在示例实施例中,方法200还包括响应于接收到请求,从节点删除至少一个键和相关联的元数据。
可以理解,在删除之后,在存储在键区域中的键之间可能会有空白空间。因此,可以如下面在图3的描述中描述的那样执行分段过程。
图3示出了根据本公开的实施例的节点的分段的方法300。方法300可以使用***102的一个或多个组件来实施。为了简洁起见,在下面的描述中可以省略已经参考上面图1、图2和图4的描述详细描述的组件的描述。
方法300开始于步骤302,其中更新键区域中多个键中的一个或多个键的位置。此外,在步骤304,基于一个或多个键中的每一个的新位置,更新与多个键中的一个或多个键相关联的对应的键元数据。
因此,可以优化给定节点中的可用空间。在示例中,方法300的分段过程可以在删除键之后自动发生。在示例中,分段过程可以基于用户输入而发生。在示例中,如下所述,分段可以响应于进一步请求的处理而发生。
在示例中,在步骤306,方法300包括接收在节点中存储另一键的进一步请求。因此,在步骤308,确定下一个键的大小是否大于节点中的可用空间。在步骤310,如果确定下一个键的大小大于可用空间,则执行分段过程。
图5示出了根据本公开的实施例的比较结果500。在第一表502中,示出了根据传统技术的用于将键存储在KV SSD的数据结构的节点中的存储空间。第二表504示出了根据所提出的主题的各方面的用于将键存储在诸如KV SSD 104的KV SSD的数据结构的节点中的存储空间。
可以看出,根据传统技术,总共2304字节被用于存储总大小为607字节的键。而在非限制性示例中,总共634字节被用于存储总大小为607字节的键。因此,将理解,所提出的主题的方面提供了一种优化在给定KV SSD的节点中提供的存储空间的解决方案。
虽然已经使用了特定的语言来描述本公开,但是不旨在由此产生的任何限制。对于本领域技术人员来说明显的是,可以对方法和/或***进行各种工作修改,以便实施本文教导的发明概念。附图和前面的描述给出了实施例的示例。本领域技术人员将理解,一个或多个所描述的元件可以很好地组合成单个功能元件。或者,特定元件可以被分成多个功能元件。一个实施例中的元件可以添加到另一实施例。

Claims (20)

1.一种方法,包括:
接收将一个或多个键存储在键值固态驱动器KV-SSD中的请求;
执行用于将所述一个或多个键存储在所述KV-SSD的数据结构的节点中的存储操作,其中,对于所述一个或多个键中的每个键的存储操作包括:
在所述节点中分配第一区域用于存储键,使得所述第一区域的大小等于所述键的大小;
在所述节点中分配第二区域用于存储与所述键相关联的键元数据,使得所述第二区域具有预定大小;以及
将所述键存储在所述节点的所述第一区域中,并将所述键元数据存储在所述节点的所述第二区域中。
2.根据权利要求1所述的方法,其中,所述键元数据包括与所述键相关联的偏移值和所述键的大小,并且其中,所述偏移值指示所述键在所述节点中的位置。
3.根据权利要求2所述的方法,其中,所述节点至少包括键区域和键元数据区域,其中,所述键区域被配置为存储所述一个或多个键,并且其中,所述键元数据区域被配置为存储与所述一个或多个键中的每一个相关联的键元数据,并且其中,所述键区域从所述节点的第一端开始,并且其中,所述键元数据区域从所述节点的第二端开始,并且其中,所述第二端与所述第一端相对。
4.根据权利要求3所述的方法,其中,所述方法还包括:
从所述节点的所述第一端开始将所述一个或多个键存储在所述键区域中;以及
从所述节点的所述第二端开始将与所述一个或多个键中的每一个相关联的键元数据存储在所述键元数据区域中。
5.根据权利要求3所述的方法,其中,所述节点还包括位于所述键区域和所述键元数据区域之间的安全区域。
6.根据权利要求3所述的方法,其中,所述节点还包括节点元数据区域,所述节点元数据区域包括关于所述节点的占用率的信息。
7.根据权利要求3所述的方法,其中,所述方法还包括:
从KV应用接收范围查询调用;以及
基于所述键元数据区域来服务所述范围查询调用。
8.根据权利要求3所述的方法,其中,所述方法还包括:
接收从所述一个或多个键中删除至少一个键的请求;
响应于所述请求的接收,从所述节点删除所述至少一个键和相关联的键元数据。
9.根据权利要求8所述的方法,其中,所述方法还包括在所述节点上执行分段过程,其中,所述分段过程包括:
更新所述键区域中的所述一个或多个键中的一个或多个键的位置;以及
基于所述一个或多个键中的每一个的新位置,更新与所述一个或多个键中的一个或多个键相关联的对应的键元数据。
10.根据权利要求9所述的方法,还包括:
接收在所述节点中存储下一个键的进一步请求;
确定所述下一个键的大小是否大于所述节点中的可用空间;以及
如果确定所述下一个键的大小大于所述可用空间,则执行所述分段过程。
11.一种***,包括:
处理器;
请求处理器,耦接到所述处理器,其中,所述请求处理器被配置为接收将多个键存储在键值固态驱动器KV-SSD中的请求;和
存储器管理器,耦接到所述处理器,其中,所述存储器管理器被配置为执行用于将所述多个键中的每个键存储在所述KV-SSD的数据结构的节点中的存储操作,并且其中,在所述存储操作中,所述存储器管理器被配置为:
在所述节点中分配第一区域用于存储键,使得所述第一区域的大小等于所述键的大小;
在所述节点中分配第二区域用于存储与所述键相关联的键元数据,使得所述第二区域具有预定大小;以及
将所述键存储在所述节点的所述第一区域中,并将所述键元数据存储在所述节点的所述第二区域中。
12.根据权利要求11所述的***,其中,所述键元数据包括与所述键相关联的偏移值和所述键的大小,其中,所述偏移值指示所述键在所述节点中的位置。
13.根据权利要求12所述的***,其中,所述节点至少包括键区域和键元数据区域,其中,所述键区域被配置为存储所述多个键,并且其中,所述键元数据区域被配置为存储与所述多个键中的每一个相关联的键元数据,并且其中,所述键区域从所述节点的第一端开始,并且其中,所述键元数据区域从所述节点的第二端开始,其中,所述第二端与所述第一端相对。
14.根据权利要求13所述的***,其中,所述存储器管理器还被配置为:
从所述节点的所述第一端开始将所述多个键存储在所述键区域中;以及
从所述节点的所述第二端开始将与所述多个键中的每一个相关联的键元数据存储在键元数据区域中。
15.根据权利要求13所述的***,其中,所述节点还包括位于所述键区域和所述键元数据区域之间的安全区域。
16.根据权利要求13所述的***,其中所述节点还包括节点元数据区域,所述节点元数据区域包括关于所述节点的占用率的信息。
17.根据权利要求13所述的***,其中,所述***还包括查询处理器,其中:
所述请求处理器被配置为从KV应用接收范围查询调用;并且
所述查询处理器被配置为基于所述键元数据区域来服务所述范围查询调用。
18.根据权利要求13所述的***,其中:
所述请求处理器还被配置为接收从所述多个键中删除至少一个键的请求;并且
所述存储器管理器还被配置为从所述节点中删除所述至少一个键和相关联的键元数据。
19.根据权利要求13所述的***,其中,所述存储器管理器还被配置为在所述节点上执行分段过程,其中,在所述分段过程中,所述存储器管理器被配置为:
更新所述键区域中的所述多个键中的一个或多个键的位置;以及
基于所述一个或多个键中的每一个的新位置,更新与所述多个键中的所述一个或多个键相关联的对应的键元数据。
20.根据权利要求19所述的***,其中:
所述请求处理器还被配置为接收在所述节点中存储下一个键的进一步请求;并且
所述存储器管理器还被配置为:
确定所述下一个键的大小是否大于所述节点中的可用空间;以及
如果确定所述下一个键的大小大于可用空间,则执行所述分段过程。
CN202210773955.5A 2021-07-07 2022-07-01 键值固态驱动器中的动态存储 Pending CN115599290A (zh)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
IN202141030420 2021-07-07
IN202141030420 2021-07-07

Publications (1)

Publication Number Publication Date
CN115599290A true CN115599290A (zh) 2023-01-13

Family

ID=84841741

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202210773955.5A Pending CN115599290A (zh) 2021-07-07 2022-07-01 键值固态驱动器中的动态存储

Country Status (2)

Country Link
US (1) US11960721B2 (zh)
CN (1) CN115599290A (zh)

Family Cites Families (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20140304525A1 (en) * 2013-04-01 2014-10-09 Nexenta Systems, Inc. Key/value storage device and method
US11275762B2 (en) * 2017-03-20 2022-03-15 Samsung Electronics Co., Ltd. System and method for hybrid data reliability for object storage devices
US10649969B2 (en) * 2017-06-13 2020-05-12 Western Digital Technologies, Inc. Memory efficient persistent key-value store for non-volatile memories
US10715499B2 (en) * 2017-12-27 2020-07-14 Toshiba Memory Corporation System and method for accessing and managing key-value data over networks
KR102535828B1 (ko) * 2018-02-06 2023-05-23 삼성전자주식회사 메모리 컨트롤러 및 상기 메모리 컨트롤러의 동작 방법
US11258796B2 (en) * 2018-07-05 2022-02-22 Fungible, Inc. Data processing unit with key value store
US11093143B2 (en) * 2019-07-12 2021-08-17 Samsung Electronics Co., Ltd. Methods and systems for managing key-value solid state drives (KV SSDS)
US11474699B1 (en) * 2021-06-07 2022-10-18 The Florida International University Board Of Trustees Systems and methods for optimizing data management within key value storage

Also Published As

Publication number Publication date
US20230019465A1 (en) 2023-01-19
US11960721B2 (en) 2024-04-16

Similar Documents

Publication Publication Date Title
CN110109915B (zh) 用于管理哈希表的方法、设备和计算机程序产品
EP3260993A1 (en) File operation method and device
US11314689B2 (en) Method, apparatus, and computer program product for indexing a file
CN108268344B (zh) 一种数据处理方法和装置
US10585807B2 (en) Balanced cache for recently frequently used data
CN111857539A (zh) 用于管理存储***的方法、设备和计算机程序产品
CN115129621B (zh) 一种内存管理方法、设备、介质及内存管理模块
US11226778B2 (en) Method, apparatus and computer program product for managing metadata migration
CN111475100B (zh) 用于管理存储***的方法、设备和计算机可读介质
US11385805B2 (en) Method, electronic device and computer program product for managing storage unit
US20200349186A1 (en) Method, apparatus and computer program product for managing metadata of storage object
CN112835740A (zh) 用于管理数据备份的方法、电子设备和计算机程序产品
CN115599290A (zh) 键值固态驱动器中的动态存储
US10678453B2 (en) Method and device for checking false sharing in data block deletion using a mapping pointer and weight bits
US20220317883A1 (en) Dynamic Base Disk Mirroring for Linked Clones
CN111488242B (zh) 将条带化备份加标签和路由到重复数据删除设备上的单个重复数据删除实例的方法和***
US11243968B2 (en) Dynamic data service engine/router for content service management
CN109343928B (zh) 虚拟化集群中虚拟机的虚拟内存文件重定向方法及其***
CN111435342A (zh) 海报的更新方法、更新***以及管理***
US11748002B2 (en) Highly concurrent data store allocation
US20220237119A1 (en) Method, electronic device and computer program product for managing storage system
US8966220B2 (en) Optimizing large page processing
CN110022348B (zh) 用于动态备份会话的***和方法
US11733903B2 (en) Data relocation for data units in scale-out storage systems
CN111881085B (zh) 一种读写带宽性能的优化方法及***

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication