CN107229429B - 一种存储空间管理方法及装置 - Google Patents

一种存储空间管理方法及装置 Download PDF

Info

Publication number
CN107229429B
CN107229429B CN201710501642.3A CN201710501642A CN107229429B CN 107229429 B CN107229429 B CN 107229429B CN 201710501642 A CN201710501642 A CN 201710501642A CN 107229429 B CN107229429 B CN 107229429B
Authority
CN
China
Prior art keywords
storage
block
storage block
idle
index
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
Application number
CN201710501642.3A
Other languages
English (en)
Other versions
CN107229429A (zh
Inventor
王永刚
范聪聪
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.)
Suzhou Inspur Intelligent Technology Co Ltd
Original Assignee
Suzhou Inspur Intelligent Technology 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 Suzhou Inspur Intelligent Technology Co Ltd filed Critical Suzhou Inspur Intelligent Technology Co Ltd
Priority to CN201710501642.3A priority Critical patent/CN107229429B/zh
Publication of CN107229429A publication Critical patent/CN107229429A/zh
Application granted granted Critical
Publication of CN107229429B publication Critical patent/CN107229429B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

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/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/061Improving I/O performance
    • 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
    • G06F3/0644Management of space entities, e.g. partitions, extents, pools

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

本发明公开了一种存储空间管理方法及装置,将存储空间划分为存储块并编号,创建空间地图树结构,当将存储任务分配到存储块时,预设查找空闲存储块的起始位置,根据所述起始位置获得所述根节点中对应的索引,根据所述索引查找到有空闲索引块的叶子节点,在所述叶子节点中进行查找获得空闲存储块,将所述存储任务存储至所述空闲存储块中。通过本发明实现了提升系统的访问效率和改善用户体验的目的。

Description

一种存储空间管理方法及装置
技术领域
本发明涉及存储技术领域,特别是涉及一种存储系统的存储空间管理方法及装置。
背景技术
在现有的存储系统中,对于存储空间的管理基本是把存储空间划分为等大小的存储块,然后把空闲的存储块通过链表的形式进行存储。在分配空闲区间时,从链表的尾部获取空闲的存储块;当空间回收时把释放的存储块再放到链表的尾部。虽然这种存储空间管理方法的优点是实现简单、空间分配和回收效率都较高,但是该种存储空间管理方法也存在着一定的缺点,在系统运行一段时间后,对于需要分配多个存储块的情况,分配的多个存储块的地址是离散的,在进行数据存储访问时进行的随机I/O访问,会导致数据的访问效率底下,客户体验差。
发明内容
针对于上述问题,本发明提供一种存储空间管理方法及装置,实现了提升系统的访问效率和改善用户体验的目的。
为了实现上述目的,根据本发明的第一方面,提供了一种存储空间管理方法,该方法包括:
将存储系统的存储空间划分为多个存储块,并对所述存储块按照存储空间的地址大小进行线性编号,获得所述存储块的编号;
设置所述存储块的比特字段,并基于所述比特字段划分得到空闲存储块,其中,所述比特位字段为0时表示所述存储块空闲,当所述比特位字段为1时标识所述存储块被使用;
创建空间地图树结构,其中,所述空间地图树包括根节点和叶子节点;
将所述存储块的使用相关信息存储到所述叶子节点中;
创建所述存储块的索引,并将所述索引存放至所述根节点;
在将存储任务分配到空闲存储块时,预设查找空闲存储块的起始位置,根据所述起始位置获得所述根节点中对应的索引,根据所述索引查找到空闲存储块的编号,基于所述编号在所述叶子节点中进行查找获得空闲存储块,将所述存储任务存储至所述空闲存储块中。
优选的,所述将所述存储块的使用信息存储到所述叶子节点中,包括:
分别设置所述叶子节点块头字段和块号字段;
将所述存储块中拥有空闲存储块的数量信息存储至所述叶子节点的块头字段;
将所述叶子节点对应的被使用的存储块的编号信息存储至所述叶子节点的块号字段。
优选的,所述创建所述存储块的索引,并将所述索引存放至所述根节点,包括:
创建所述存储块的索引;
分别设置索引块号字段和空闲指向字段;
将所述索引指向的叶子节点对应的存储块的编号存储至所述索引块号字段;
将所述索引指向的叶子节点对应的存储块中空闲存储块的数量信息存储至所述空闲指向字段。
优选的,所述在将存储任务分配到空闲存储块时,预设查找空闲存储块的起始位置,根据所述起始位置获得所述根节点中对应的索引,根据所述索引查找到有空闲存储块的编号,基于所述编号在所述叶子节点中进行查找获得空闲存储块,将所述存储任务存储至所述空闲存储块中,包括:
在将存储任务分配到空闲存储块时,获取到上一次存储任务分配到的空闲存储块的编号,将所述编号数值加一获得查找空闲存储块的起始存储块的编号;
根据起始存储块的编号,查找获得对应的所述根节点中的索引的空闲标识字段;
解析所述空闲标识字段,获得空闲存储块的编号;
基于所述编号,查找获得所述叶子节点中的空闲存储块位置信息;
查找所述空闲存储块位置信息对应的存储块,得到空闲存储块;
将所述存储任务存储至所述空闲存储块中。
优选的,当对存储块进行存储空间释放时,该方法还包括:
将所述存储空间待释放的存储块的比特字段设置为0。
根据本发明的第二方面,提供了一种存储空间管理装置,该装置包括:
划分模块,用于将存储系统的存储空间划分为多个存储块,并对所述存储块按照存储空间的地址大小进行线性编号,获得所述存储块的编号;
设置模块,用于设置所述存储块的比特字段,并基于所述比特字段划分得到空闲存储块,其中,所述比特位字段为0时表示所述存储块空闲,当所述比特位字段为1时标识所述存储块被使用;
创建模块,用于创建空间地图树结构,其中,所述空间地图树包括根节点和叶子节点;
第一存储模块,用于将所述存储块的使用相关信息存储到所述叶子节点中;
第二存储模块,用于创建所述存储块的索引,并将所述索引存放至所述根节点;
分配模块,用于在将存储任务分配到空闲存储块时,预设查找空闲存储块的起始位置,根据所述起始位置获得所述根节点中对应的索引,根据所述索引查找到空闲存储块的编号,基于所述编号在所述叶子节点中进行查找获得空闲存储块,将所述存储任务存储至所述空闲存储块中。
优选的,所述第一存储模块包括:
第一设置单元,用于分别设置所述叶子节点块头字段和块号字段;
第一存储单元,用于将所述存储块中拥有空闲存储块的数量信息存储至所述叶子节点的块头字段;
第二存储单元,用于将所述叶子节点对应的被使用的存储块的编号信息存储至所述叶子节点的块号字段。
优选的,所述第二存储模块包括:
创建单元,用于创建所述存储块的索引;
第二设置单元,用于分别设置索引块号字段和空闲指向字段;
第三存储单元,用于将所述索引指向的叶子节点对应的存储块的编号存储至所述索引块号字段;
第四存储单元,用于将所述索引指向的叶子节点对应的存储块中空闲存储块的数量信息存储至所述空闲指向字段。
优选的,当将存储任务分配到存储块时,所述分配模块包括:
第一获取单元,用于在将存储任务分配到空闲存储块时,获取到上一次存储任务分配到的空闲存储块的编号,将所述编号数值加一获得查找空闲存储块的起始存储块的编号;
第二获取单元,用于根据起始存储块查找获得所述根节点中的索引的空闲标识字段;
第三获取单元,用于解析所述空闲标识字段,获得空闲存储块的编号;
第一查找单元,用于基于所述编号,查找获得所述叶子节点中的空闲存储块位置信息;
第二查找单元,用于查找所述空闲存储块位置信息对应的存储块,得到空闲存储块;
任务存储单元,用于将所述存储任务存储至所述空闲存储块中。
优选的,当对存储块进行存储空间释放时,该装置还包括:
释放设置模块,用于将所述存储空间待释放的存储块的比特字段设置为0。
相较于现有技术,本发明将存储空间划分为多个存储块,并对所述存储块按照存储空间的地址大小进行线性编号;创建空间地图树结构,将所述存储块的使用相关信息存储到所述叶子节点中,创建所述存储块的索引,并将所述索引存放至所述根节点;当将存储任务分配到存储块时,预设查找空闲存储块的起始位置,根据所述起始位置获得所述根节点中对应的索引,根据所述索引查找到有空闲索引块的叶子节点,在所述叶子节点中进行查找获得空闲存储块,将所述存储任务存储至所述空闲存储块中。在本发明中由于将存储块按照存储空间的地址大小进行线性编号,保证存储块的地址是连续的或者是按照存储空间地址进行递增的,并创建了空间地图树的结构,在分配存储块时先设定起始查找位置然后根据根节点对应的索引查找到叶子节点中的空闲存储块,这样保证了查找从上一次获得的空闲块之后进行,提升了数据访问效率,进而实现了改善用户体验的目的。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据提供的附图获得其他的附图。
图1为本发明实施例一提供的一种存储空间管理方法的流程示意图;
图2为本发明实施中空间地图树的示意图;
图3为本发明实施例二中对应图1步骤S14将信息存储到叶子节点的流程示意图;
图4为本发明实施例二中对应图1步骤S15将信息存储到根节点的流程示意图;
图5为本发明实施例二中对应图1步骤S16查询空闲存储块的流程示意图;
图6为本发明实施例三提供的一种存储空间管理方法的结构示意图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
本发明的说明书和权利要求书及上述附图中的术语“第一”和“第二”等是用于区别不同的对象,而不是用于描述特定的顺序。此外术语“包括”和“具有”以及他们任何变形,意图在于覆盖不排他的包含。例如包含了一系列步骤或单元的过程、方法、系统、产品或设备没有设定于已列出的步骤或单元,而是可包括没有列出的步骤或单元。
实施例一
参见图1为本发明实施例一提供的一种存储空间管理方法,该方法包括以下步骤:
S11、将存储系统的存储空间划分为多个存储块,并对所述存储块按照存储空间的地址大小进行线性编号,获得所述存储块的编号;
具体的,将所述存储系统的存储空间划分为多个等大小的存储块,所述存储块是存储设备进行存储空间分配和释放的基本单位,这些存储块按照存储空间的地址大小进行线性编号,在本发明实施例中将存储空间划分为多个4K大小的存储块,这个大小值是可以改变的,只是本发明优选4K,这个值的大小决定了每次申请存储空间的粒度。
S12、设置所述存储块的比特字段,并基于所述比特字段划分得到空闲存储块,其中,所述比特位字段为0时表示所述存储块空闲,当所述比特位字段为1时标识所述存储块被使用;
S13、创建空间地图树结构,其中,所述空间地图树包括根节点和叶子节点;
具体的,在本发明中把存储块的空闲与否的信息组织成了空间地图树(space maptree)的形式,类似于B+树的形式,具体的形式参见图2,图2为本发明实施例中提供的空间地图树的示意图,这棵树只包含根节点和叶子节点,并且存储块编号为0的存储块固定存放超级块信息,所述超级块保存了space map tree的根节点信息。
S14、将所述存储块的使用相关信息存储到所述叶子节点中;
S15、创建所述存储块的索引,并将所述索引存放至所述根节点;
具体的,在本发明的实施例中space map tree的根节点包含了255个索引,当然这个索引值是可以改变的,这个索引值的多少决定了能够索引到下一级节点的数量。
S16、在将存储任务分配到空闲存储块时,预设查找空闲存储块的起始位置,根据所述起始位置获得所述根节点中对应的索引,根据所述索引查找到空闲存储块的编号,基于所述编号在所述叶子节点中进行查找获得空闲存储块,将所述存储任务存储至所述空闲存储块中。
通过本发明实施例一公开的技术方案,将存储空间划分为多个存储块,并对所述存储块按照存储空间的地址大小进行线性编号;创建空间地图树结构,将所述存储块的使用相关信息存储到所述叶子节点中,创建所述存储块的索引,并将所述索引存放至所述根节点;当将存储任务分配到存储块时,预设查找空闲存储块的起始位置,根据所述起始位置获得所述根节点中对应的索引,根据所述索引查找到有空闲索引块的叶子节点,在所述叶子节点中进行查找获得空闲存储块,将所述存储任务存储至所述空闲存储块中。在本发明中由于将存储块按照存储空间的地址大小进行线性编号,保证存储块的地址是连续的或者是按照存储空间地址进行递增的,并创建了空间地图树的结构,在分配存储块时先设定起始查找位置然后根据根节点对应的索引查找到叶子节点中的空闲存储块,这样保证了查找从上一次获得的空闲块之后进行,提升了数据访问效率,进而实现了改善用户体验的目的。
实施例二
参照本发明实施例一和图1中所描述的S11到S16步骤的具体过程,并参见图2为本发明实施例中空间地图树的示意图,参见图3,所述步骤S14将所述存储块的使用相关信息存储到所述叶子节点中具体包括:
S141、分别设置所述叶子节点块头字段和块号字段;
S142、将所述存储块中拥有空闲存储块的数量信息存储至所述叶子节点的块头字段;
S143、将所述叶子节点对应的被使用的存储块的编号信息存储至所述叶子节点的块号字段。
可以理解的是,在叶子节点所在的存储块上,块头字段not_used表示该叶子节点对应的存储块中有多少个空闲块;所述块号字段blocknr表示该叶子节点所使用的存储块的编号。因为用一个比特字段标识一个块的使用情况,根据在本发明实施例中设置的存储块的大小为4K,以及在叶子节点上用一个字节表示一个存储块的使用情况,因此一个叶子节点能够管理(4096-16)*8=32640个存储块的使用情况,该数量是基于本发明实施例中的数据设置得到的,具体数据设置不同则数量会有所变化,本发明不一一举例说明。
对应的,参见图4,所述步骤S15创建所述存储块的索引,并将所述索引存放至所述根节点,包括:
S151、创建所述存储块的索引;
S152、分别设置索引块号字段和空闲指向字段;
S153、将所述索引指向的叶子节点对应的存储块的编号存储至所述索引块号字段;
S154、将所述索引指向的叶子节点对应的存储块中空闲存储块的数量信息存储至所述空闲指向字段。
具体的,将空间地图树的根节点设置为255个索引,索引中的索引块字段即blocknr字段表示该索引指向的叶子节点的存储块的编号,所述空闲指向字段nr_free表示该索引指向的叶子节点对应的存储块中有多少个空闲块,因此对应步骤S14中的计算过程,在此根节点中的索引所指向的是存储号为0到32639的使用情况,以此类推,在叶子节点中找到空闲的存储块可以计算出对应的编号。
对应的,参见图5,在将存储任务分配到空闲存储块时,所述步骤S16预设查找空闲存储块的起始位置,根据所述起始位置获得所述根节点中对应的索引,根据所述索引查找到有空闲索引块的叶子节点,在所述叶子节点中进行查找获得空闲存储块,将所述存储任务存储至所述空闲存储块中,具体包括:
S161、在将存储任务分配到空闲存储块时,获取到上一次存储任务分配到的空闲存储块的编号,将所述编号数值加一获得查找空闲存储块的起始存储块的编号;
S162、根据起始存储块的编号,查找获得对应的所述根节点中的索引的空闲标识字段;
S163、解析所述空闲标识字段,获得空闲存储块的编号;
S164、基于所述编号,查找获得所述叶子节点中的空闲存储块位置信息;
S165、查找所述空闲存储块位置信息对应的存储块,得到空闲存储块;
S166、将所述存储任务存储至所述空闲存储块中。
可以理解的是,在分配存储块时,为了快速找到空闲的存储块,需要通过全局变量维护了一个开始查找空闲存储块的开始位置,这个开始位置为上一次申请空闲存储块的编号加一,同时树的根节点中的索引对象的空闲标识字段none_free_before字段表示该索引指向的叶子节点中在none_free_before字段这个值之后的位置开始查找空闲块,none_free_before字段为上次从这个节点申请的空闲存储块的bit位加一,综上,在申请空闲存储块时通过开始位置确定了从哪个索引开始查找空闲块,从索引中的none_free_before字段确定了从该索引指向的叶子节点中的那个bit位开始变量查找空闲块。
对应的,当对存储块进行存储空间释放时,该方法还包括:
将所述存储空间待释放的存储块的比特字段设置为0。
具体的,对应步骤S16把开始查找空闲块的起始位置,设置为释放的这个空闲块的编号,同时可以把根节点中的none_free_before字段设置为这个释放的存储块的bit位的位置。
根据本发明实施例二公开的技术方案,具体描述了创建的空间地图树结构,并且通过该结构中的根节点和叶子节点中相关字段的设置,在分配存储块时先设定起始查找位置然后根据根节点对应的索引查找到叶子节点中的空闲存储块;并且在释放存储块空间时也对应对空间地图树中对应的信息进行了设置,通过对存储空间的分配和释放实现了对存储系统中存储空间的管理。由于在进行空间的管理时,存储块的地址是连续的或者是按照存储空间地址递增的,因此在进行数据访问时,进行的是顺序I/O访问,这有效的提升了系统的访问效率,改善了用户体验。
实施例三
与本发明实施例一和实施例二所公开的存储空间管理方法相对应,本发明的实施例三还提供了一种存储空间管理装置,参见图6,该装置包括:
划分模块1,用于将存储系统的存储空间划分为多个存储块,并对所述存储块按照存储空间的地址大小进行线性编号,获得所述存储块的编号;
设置模块2,用于设置所述存储块的比特字段,并基于所述比特字段划分得到空闲存储块,其中,所述比特位字段为0时表示所述存储块空闲,当所述比特位字段为1时标识所述存储块被使用;
创建模块3,用于创建空间地图树结构,其中,所述空间地图树包括根节点和叶子节点;
第一存储模块4,用于将所述存储块的使用相关信息存储到所述叶子节点中;
第二存储模块5,用于创建所述存储块的索引,并将所述索引存放至所述根节点;
分配模块6,用于在将存储任务分配到空闲存储块时,预设查找空闲存储块的起始位置,根据所述起始位置获得所述根节点中对应的索引,根据所述索引查找到空闲存储块的编号,基于所述编号在所述叶子节点中进行查找获得空闲存储块,将所述存储任务存储至所述空闲存储块中。
具体的,所述第一存储模块4包括:
第一设置单元41,用于分别设置所述叶子节点块头字段和块号字段;
第一存储单元42,用于将所述存储块中拥有空闲存储块的数量信息存储至所述叶子节点的块头字段;
第二存储单元43,用于将所述叶子节点对应的被使用的存储块的编号信息存储至所述叶子节点的块号字段。
对应的,所述第二存储模块5包括:
创建单元51,用于创建所述存储块的索引;
第二设置单元52,用于分别设置索引块号字段和空闲指向字段;
第三存储单元53,用于将所述索引指向的叶子节点对应的存储块的编号存储至所述索引块号字段;
第四存储单元54,用于将所述索引指向的叶子节点对应的存储块中空闲存储块的数量信息存储至所述空闲指向字段。
具体的,所述分配模块6包括:
第一获取单元61,用于在将存储任务分配到空闲存储块时,获取到上一次存储任务分配到的空闲存储块的编号,将所述编号数值加一获得查找空闲存储块的起始存储块的编号;
第二获取单元62,用于根据起始存储块查找获得所述根节点中的索引的空闲标识字段;
第三获取单元63,用于解析所述空闲标识字段,获得空闲存储块的编号;
第一查找单元64,用于基于所述编号,查找获得所述叶子节点中的空闲存储块位置信息;
第二查找单元65,用于查找所述空闲存储块位置信息对应的存储块,得到空闲存储块;
任务存储单元66,用于将所述存储任务存储至所述空闲存储块中。
对应的,当对存储块进行存储空间释放时,该装置还包括:
释放设置模块,用于将所述存储空间待释放的存储块的比特字段设置为0。
在本发明的实施例三中,通过划分模块将存储空间划分为多个存储块,通过设置模块设置存储块的比特字段区分所述存储块是否空闲,然后创建一种空间地图树用来描述各个存储块,将所述存储块的使用相关信息存储到所述叶子节点中;创建所述存储块的索引,并将所述索引存放至所述根节点;在将存储任务分配到空闲存储块时,预设查找空闲存储块的起始位置,根据所述起始位置获得所述根节点中对应的索引,根据所述索引查找到空闲存储块的编号,基于所述编号在所述叶子节点中进行查找获得空闲存储块,将所述存储任务存储至所述空闲存储块中。并且还包括对存储块空间的释放,通过对存储空间的分配和释放实现了对存储系统中存储空间的管理。由于在进行空间的管理时,存储块的地址是连续的或者是按照存储空间地址递增的,因此在进行数据访问时,进行的是顺序I/O访问,这有效的提升了系统的访问效率,改善了用户体验。
本说明书中各个实施例采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似部分互相参见即可。对于实施例公开的装置而言,由于其与实施例公开的方法相对应,所以描述的比较简单,相关之处参见方法部分说明即可。
对所公开的实施例的上述说明,使本领域专业技术人员能够实现或使用本发明。对这些实施例的多种修改对本领域的专业技术人员来说将是显而易见的,本文中所定义的一般原理可以在不脱离本发明的精神或范围的情况下,在其它实施例中实现。因此,本发明将不会被限制于本文所示的这些实施例,而是要符合与本文所公开的原理和新颖特点相一致的最宽的范围。

Claims (10)

1.一种存储空间管理方法,其特征在于,该方法包括:
将存储系统的存储空间划分为多个存储块,并对所述存储块按照存储空间的地址大小进行线性编号,获得所述存储块的编号;
设置所述存储块的比特字段,并基于所述比特字段划分得到空闲存储块,其中,所述比特字段为0时表示所述存储块空闲,当所述比特字段为1时标识所述存储块被使用;
创建空间地图树结构,其中,所述空间地图树包括根节点和叶子节点;
将所述存储块的使用相关信息存储到所述叶子节点中;
创建所述存储块的索引,并将所述索引存放至所述根节点;
在将存储任务分配到空闲存储块时,预设查找空闲存储块的起始位置,根据所述起始位置获得所述根节点中对应的索引,根据所述索引查找到空闲存储块的编号,基于所述编号在所述叶子节点中进行查找获得空闲存储块,将所述存储任务存储至所述空闲存储块中。
2.根据权利要求1所述的方法,其特征在于,所述将所述存储块的使用信息存储到所述叶子节点中,包括:
分别设置所述叶子节点块头字段和块号字段;
将所述存储块中拥有空闲存储块的数量信息存储至所述叶子节点的块头字段;
将所述叶子节点对应的被使用的存储块的编号信息存储至所述叶子节点的块号字段。
3.根据权利要求1所述的方法,其特征在于,所述创建所述存储块的索引,并将所述索引存放至所述根节点,包括:
创建所述存储块的索引;
分别设置索引块号字段和空闲指向字段;
将所述索引指向的叶子节点对应的存储块的编号存储至所述索引块号字段;
将所述索引指向的叶子节点对应的存储块中空闲存储块的数量信息存储至所述空闲指向字段。
4.根据权利要求1所述的方法,其特征在于,所述在将存储任务分配到空闲存储块时,预设查找空闲存储块的起始位置,根据所述起始位置获得所述根节点中对应的索引,根据所述索引查找到有空闲存储块的编号,基于所述编号在所述叶子节点中进行查找获得空闲存储块,将所述存储任务存储至所述空闲存储块中,包括:
在将存储任务分配到空闲存储块时,获取到上一次存储任务分配到的空闲存储块的编号,将所述编号数值加一获得查找空闲存储块的起始存储块的编号;
根据起始存储块的编号,查找获得对应的所述根节点中的索引的空闲标识字段;
解析所述空闲标识字段,获得空闲存储块的编号;
基于所述编号,查找获得所述叶子节点中的空闲存储块位置信息;
查找所述空闲存储块位置信息对应的存储块,得到空闲存储块;
将所述存储任务存储至所述空闲存储块中。
5.根据权利要求1所述的方法,其特征在于,当对存储块进行存储空间释放时,该方法还包括:
将所述存储空间待释放的存储块的比特字段设置为0。
6.一种存储空间管理装置,其特征在于,该装置包括:
划分模块,用于将存储系统的存储空间划分为多个存储块,并对所述存储块按照存储空间的地址大小进行线性编号,获得所述存储块的编号;
设置模块,用于设置所述存储块的比特字段,并基于所述比特字段划分得到空闲存储块,其中,所述比特字段为0时表示所述存储块空闲,当所述比特字段为1时标识所述存储块被使用;
创建模块,用于创建空间地图树结构,其中,所述空间地图树包括根节点和叶子节点;
第一存储模块,用于将所述存储块的使用相关信息存储到所述叶子节点中;
第二存储模块,用于创建所述存储块的索引,并将所述索引存放至所述根节点;
分配模块,用于在将存储任务分配到空闲存储块时,预设查找空闲存储块的起始位置,根据所述起始位置获得所述根节点中对应的索引,根据所述索引查找到空闲存储块的编号,基于所述编号在所述叶子节点中进行查找获得空闲存储块,将所述存储任务存储至所述空闲存储块中。
7.根据权利要求6所述的装置,其特征在于,所述第一存储模块包括:
第一设置单元,用于分别设置所述叶子节点块头字段和块号字段;
第一存储单元,用于将所述存储块中拥有空闲存储块的数量信息存储至所述叶子节点的块头字段;
第二存储单元,用于将所述叶子节点对应的被使用的存储块的编号信息存储至所述叶子节点的块号字段。
8.根据权利要求6所述的装置,其特征在于,所述第二存储模块包括:
创建单元,用于创建所述存储块的索引;
第二设置单元,用于分别设置索引块号字段和空闲指向字段;
第三存储单元,用于将所述索引指向的叶子节点对应的存储块的编号存储至所述索引块号字段;
第四存储单元,用于将所述索引指向的叶子节点对应的存储块中空闲存储块的数量信息存储至所述空闲指向字段。
9.根据权利要求6所述的装置,其特征在于,当将存储任务分配到存储块时,所述分配模块包括:
第一获取单元,用于在将存储任务分配到空闲存储块时,获取到上一次存储任务分配到的空闲存储块的编号,将所述编号数值加一获得查找空闲存储块的起始存储块的编号;
第二获取单元,用于根据起始存储块查找获得所述根节点中的索引的空闲标识字段;
第三获取单元,用于解析所述空闲标识字段,获得空闲存储块的编号;
第一查找单元,用于基于所述编号,查找获得所述叶子节点中的空闲存储块位置信息;
第二查找单元,用于查找所述空闲存储块位置信息对应的存储块,得到空闲存储块;
任务存储单元,用于将所述存储任务存储至所述空闲存储块中。
10.根据权利要求6所述的装置,其特征在于,当对存储块进行存储空间释放时,该装置还包括:
释放设置模块,用于将所述存储空间待释放的存储块的比特字段设置为0。
CN201710501642.3A 2017-06-27 2017-06-27 一种存储空间管理方法及装置 Active CN107229429B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201710501642.3A CN107229429B (zh) 2017-06-27 2017-06-27 一种存储空间管理方法及装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201710501642.3A CN107229429B (zh) 2017-06-27 2017-06-27 一种存储空间管理方法及装置

Publications (2)

Publication Number Publication Date
CN107229429A CN107229429A (zh) 2017-10-03
CN107229429B true CN107229429B (zh) 2020-06-16

Family

ID=59936610

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201710501642.3A Active CN107229429B (zh) 2017-06-27 2017-06-27 一种存储空间管理方法及装置

Country Status (1)

Country Link
CN (1) CN107229429B (zh)

Families Citing this family (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN108196966A (zh) * 2018-01-29 2018-06-22 天津芯海创科技有限公司 多数据源的数据比对方法、装置和芯片
CN109086002A (zh) * 2018-06-28 2018-12-25 平安科技(深圳)有限公司 存储对象的空间管理方法、装置、计算机装置及存储介质
CN109710542B (zh) * 2018-12-28 2021-03-16 北京像素软件科技股份有限公司 一种满n叉树构建方法及装置
CN110275864B (zh) * 2019-06-11 2021-07-16 武汉深之度科技有限公司 索引建立方法、数据查询方法及计算设备
CN114706527B (zh) * 2022-03-24 2022-09-20 北京涵鑫盛科技有限公司 一种存储空间分布式的释放方法及分布式系统

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101681315A (zh) * 2008-03-01 2010-03-24 株式会社东芝 存储器系统
CN103907099A (zh) * 2011-11-02 2014-07-02 华为技术有限公司 高速缓存一致性计算机系统中未缓存的短地址转换表
CN104487951A (zh) * 2012-05-15 2015-04-01 日本电气株式会社 分布式数据管理设备和分布式数据操作设备
CN104536908A (zh) * 2014-11-05 2015-04-22 北京中安比特科技有限公司 一种面向单机的海量小记录高效存储管理方法
CN105637491A (zh) * 2014-09-26 2016-06-01 华为技术有限公司 一种文件迁移方法、装置和存储设备

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10025806B2 (en) * 2015-08-27 2018-07-17 Vmware, Inc. Fast file clone using copy-on-write B-tree

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101681315A (zh) * 2008-03-01 2010-03-24 株式会社东芝 存储器系统
CN103907099A (zh) * 2011-11-02 2014-07-02 华为技术有限公司 高速缓存一致性计算机系统中未缓存的短地址转换表
CN104487951A (zh) * 2012-05-15 2015-04-01 日本电气株式会社 分布式数据管理设备和分布式数据操作设备
CN105637491A (zh) * 2014-09-26 2016-06-01 华为技术有限公司 一种文件迁移方法、装置和存储设备
CN104536908A (zh) * 2014-11-05 2015-04-22 北京中安比特科技有限公司 一种面向单机的海量小记录高效存储管理方法

Also Published As

Publication number Publication date
CN107229429A (zh) 2017-10-03

Similar Documents

Publication Publication Date Title
CN107229429B (zh) 一种存储空间管理方法及装置
CN107015985B (zh) 一种数据存储与获取方法及装置
CN106326309B (zh) 一种数据查询方法和装置
CN105653537B (zh) 一种数据库应用系统的分页查询方法和装置
CN106294190B (zh) 一种存储空间管理方法及装置
CN103714013B (zh) 一种文件系统的存储空间的配置方法及装置
CN102915382A (zh) 一种基于索引的数据库的数据查询方法和装置
CN106708822B (zh) 一种文件存储方法和装置
CN105338073A (zh) 一种文件目录的处理方法、服务器和系统
CN112765405A (zh) 空间数据搜索结果的聚类和查询的方法及系统
CN113268439A (zh) 内存地址的查找方法和装置、电子设备和存储介质
CN108154024B (zh) 一种数据检索方法、装置及电子设备
CN109977373B (zh) 标识号分配方法、标识号回收方法及装置
CN106550006A (zh) 云服务器资源分配方法和装置
CN105389266A (zh) 一种数据管理方法及装置
CN103905512A (zh) 一种数据处理方法和设备
CN110765073B (zh) 分布式存储系统的文件管理方法、介质、设备及装置
CN110825953B (zh) 数据查询方法、装置和设备
CN107111549B (zh) 一种文件系统的管理方法及装置
CN108376054B (zh) 一种对标识数据进行索引的处理方法及装置
CN112632058A (zh) 轨迹确定方法、装置及设备、存储介质
CN105653540B (zh) 文件属性信息的处理方法和装置
CN103092767A (zh) 一种对云计算内部物理机信息内存池的管理方法
CN115454353A (zh) 一种面向空间应用数据的高速写入及查询方法
CN112650964B (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

Effective date of registration: 20200520

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.

TA01 Transfer of patent application right
GR01 Patent grant
GR01 Patent grant