CN113688130A - 一种内存数据库存储引擎管理方法 - Google Patents

一种内存数据库存储引擎管理方法 Download PDF

Info

Publication number
CN113688130A
CN113688130A CN202110894627.6A CN202110894627A CN113688130A CN 113688130 A CN113688130 A CN 113688130A CN 202110894627 A CN202110894627 A CN 202110894627A CN 113688130 A CN113688130 A CN 113688130A
Authority
CN
China
Prior art keywords
art
index
memory
data
storage engine
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
Application number
CN202110894627.6A
Other languages
English (en)
Other versions
CN113688130B (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.)
Shanghai Yunxi Technology Co ltd
Original Assignee
Inspur Cloud Information 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 Inspur Cloud Information Technology Co Ltd filed Critical Inspur Cloud Information Technology Co Ltd
Priority to CN202110894627.6A priority Critical patent/CN113688130B/zh
Publication of CN113688130A publication Critical patent/CN113688130A/zh
Application granted granted Critical
Publication of CN113688130B publication Critical patent/CN113688130B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/22Indexing; Data structures therefor; Storage structures
    • G06F16/2228Indexing structures
    • G06F16/2255Hash tables
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/22Indexing; Data structures therefor; Storage structures
    • G06F16/2228Indexing structures
    • G06F16/2246Trees, e.g. B+trees
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/24Querying
    • G06F16/245Query processing
    • G06F16/2455Query execution
    • G06F16/24553Query execution of query operations
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D10/00Energy efficient computing, e.g. low power processors, power management or thermal management

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Data Mining & Analysis (AREA)
  • Databases & Information Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Software Systems (AREA)
  • Computational Linguistics (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本发明特别涉及一种内存数据库存储引擎管理方法。该内存数据库存储引擎管理方法,基于RocksDB存储引擎的Memtable管理机制,在Memtable内部新建ART索引用以取代skiplist索引,采用ART索引加Hash索引的双索引机制查询key‑value,优化RocksDB存储引擎的读性能,从而实现RocksDB内存引擎模式,减少磁盘读写,提高查询速度。该内存数据库存储引擎管理方法,优化了现有分布式NewSQL数据库中基于RocksDB存储引擎的读性能问题,充分发挥了内存的高效读写性能,能够在内存中缓存更多的数据,解决了RocksDB的读放大问题。

Description

一种内存数据库存储引擎管理方法
技术领域
本发明涉及数据库管理技术领域,特别涉及一种内存数据库存储引擎管理方法。
背景技术
近年来,随着动态随机存储器(DRAM)容量的上升和单位价格的下降,使大量数据在内存中的存储和处理成为可能。相对于磁盘,内存的数据读写速度要高出几个数量级,将数据保存在内存中相比从磁盘上访问能够极大地提高应用的性能。
CockroachDB是一款开源的分布式数据库,具有NoSQL对海量数据的存储管理能力,又保持了传统数据库支持的ACID和SQL等,还支持跨地域、去中心、高并发、多副本强一致和高可用等特性。支持OLTP场景,同时支持轻量级OLAP场景。
CockroachDB使用RocksDB作为KV存储引擎,RocksDB是一个高性能的Key-Value数据库。RocksDB是基于LSM做存储,RocksDB在内存中的结构叫做Memtable,用于形成Log-Structured的file叫做logfile,磁盘上的file结构叫做sstfile,用于记录对file更改的log叫做manifest。
LSM存储模型的所有写操作都是顺序写,在稍微损失读性能的情况下,极大地提高了数据的写性能。换来的代价是读性能和增加合并的开销:RocksDB单列族的Memtable默认有64MB,超过这个大小时,写入数据会从Memtable转换为immutable Memtable,然后启动后台线程定时对写入immutable Memtable的数据进行Compaction压缩操作,以进行资源的回收;并将immutable Memtable加入flush pipeline,等待后台线程去flush到SST中,导致读放大问题,查询一个Key值所对应的Value值,可能需要遍历多个SSTable文件,对应了复数次随机IO。而且空间放大,多版本数据在合并之前会占用更多的存储空间。
为了优化现有分布式NewSQL数据库中基于RocksDB存储引擎的读放大问题,优化基于ART算法的内存数据库的读性能问题,本发明提出了一种内存数据库存储引擎管理方法。
发明内容
本发明为了弥补现有技术的缺陷,提供了一种简单高效的内存数据库存储引擎管理方法。
本发明是通过如下技术方案实现的:
一种内存数据库存储引擎管理方法,其特征在于:基于RocksDB存储引擎的Memtable管理机制,在Memtable内部新建ART索引用以取代skiplist索引,采用ART索引加Hash索引的双索引机制查询key-value,优化RocksDB存储引擎的读性能,从而实现RocksDB内存引擎模式,减少磁盘读写,提高查询速度。
该内存数据库存储引擎管理方法,具体实现过程如下:
1)将插入Memtable的数据转为插入到ART算法管理的内存块中,并将ART算法的叶节点地址加入Hash索引中;
2)修改Memtable刷盘的逻辑,使得Memtable永不转换imMemtable,通过内存块的形式进行刷盘,内存块通过双向链表进行管理;
3)执行查询操作时,先从Hash表中查询,然后查询ART树,最后查询磁盘SST文件。
所述步骤1)中,写入的数据在内存中以内存块的形式存储,通过双向链表对key进行排序,双向链表的每个节点内存储当前key对应的多个版本数据形成的链表,双向链表的每个节点指向内存块存储的该key对应的key-value;所述ART索引用于快速定位双向链表的特定节点,所述Hash索引用于快速查询ART树的叶子节点的地址;
写入数据时,首先通过Hash索引与ART索引计算待插入的叶子结点位置,然后根据ART的叶子节点添加双向链表,通过双向链表对业务key进行排序。
所述步骤1)中,当有新的key插入叶子节点时,使用ART算法快速定位到双向链表的插入节点进行插入,同时增加hash表的插入逻辑,对Hash表加锁;将key的String类型作为Hash表中的key,将叶子节点指针位置作为Hash表中的value插入到Hash表中。
所述步骤1)中,新建一个ART索引维护类,使用ART算法替换Memtable中的skiplist算法;在ART索引维护类中新建一个Hash索引类成员HashMap(哈希映射),用于ART索引叶节点的快速查询。
所述步骤1)中,使用PureMemRep类继承public MemtableRep,新增Memtable的内存仓库管理类,使用InlineART类替换InlinSkiplist类,用以实现基于ART算法的内存数据索引;
在InlineART类中增加类成员HashTable(hash表),hash表中存放ART叶节点和key。
所述步骤2)中,启用异步刷盘线程,维护所有内存块的队列,队列按照内存块的上次刷盘时间排序;线程从队列取内存块,并将内存块增量的kv数据(key-value)进行落盘,追加到文件末尾或形成新的磁盘SST文件。
内存块一般具有固定大小,用于存储数据库插入时传入的KV数据。按照传入的先后顺序顺序排放存储在内存块中。内存块存放满时,创建新的内存块存放新插入的KV数据。
所述步骤3)中,调用Memtable::NewIterator接口创建基于ART树的Iterator(迭代器),用于遍历ART树中的节点;
新建Memtable::NewHashIterator接口,增加ReadOptions参数,用于判断是否为MVCCGet读取;如果是则调用NewHashIterator接口,直接从Hash表中查找存储key的双向链表所对应的叶子节点,如果不是则调用NewIterator接口在hash索引中查找叶子节点,若没有再去ART索引查询;
最终得到ART树的叶子节点,得到存储多版本key的双向链表,通过遍历双向链表得到内存块中的数据(key-value)。
所述步骤3)中,当读取多版本数据即MVCCGet数据时,在Hash表中取出key对应的叶子节点,然后从叶子节点对应的双向链表中取出对应的key;如果hash索引中没有查到key,说明已经数据已经落盘,则去磁盘SST文件中查找;
当读取非MVCCGet数据时,则在hash索引中查找对应的叶子节点,若没找到对应的叶子节点,则在ART树中查找叶子节点,若ART树中没有找到对应的叶子节点,则去磁盘SST(Silicon Storage Technology,硅存储)文件中查找。
本发明的有益效果是:该内存数据库存储引擎管理方法,优化了现有分布式NewSQL数据库中基于RocksDB存储引擎的读性能问题,充分发挥了内存的高效读写性能,能够在内存中缓存更多的数据,解决了RocksDB的读放大问题。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
附图1为本发明内存数据库存储引擎管理方法示意图。
具体实施方式
为了使本技术领域的人员更好的理解本发明中的技术方案,下面将结合本发明实施例,对本发明实施例中的技术方案进行清楚,完整的描述。显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都应当属于本发明保护的范围。
ART(Adaptive Radix Tree,自适应基数/前缀树)是以二进制位串为关键字的trie树,是一种多叉树形结构,同时又类似多层索引表,每个中间节点包含指向多个子节点的指针数组,叶子节点包含指向实际的对象的指针。中间节点根据长度的不同分成若干种不同类型,随着数据的变化而自行调整。虽然使用基于ART树构建的KV内存存储引擎会具备很好的性能优势,但由于树的高度取决于key的长度,时间复杂度取决于key的长度,所以当key的长度增加时,性能会下降,存在性能瓶颈。
哈希索引(hash index)基于哈希表实现,只有精确匹配索引key的查询才有效。对于每个key,存储引擎都会对所有的value计算一个哈希码(hash code),哈希码是一个较小的值,并且不同key值计算出来的哈希码也不一样。哈希索引将所有的哈希码存储在索引中,同时在哈希表中保存指向每个key的指针。Hash索引结构的特殊性,其检索效率非常高,索引的检索可以一次定位。
该内存数据库存储引擎管理方法,基于RocksDB存储引擎的Memtable管理机制,在Memtable内部新建ART索引用以取代skiplist索引,采用ART索引加Hash索引的双索引机制查询key-value,优化RocksDB存储引擎的读性能,从而实现RocksDB内存引擎模式,减少磁盘读写,提高查询速度。
该内存数据库存储引擎管理方法,具体实现过程如下:
1)将插入Memtable的数据转为插入到ART算法管理的内存块中,并将ART算法的叶节点地址加入Hash索引中;
2)修改Memtable刷盘的逻辑,使得Memtable永不转换imMemtable,通过内存块的形式进行刷盘,内存块通过双向链表进行管理;
3)执行查询操作时,先从Hash表中查询,然后查询ART树,最后查询磁盘SST文件。
所述步骤1)中,写入的数据在内存中以内存块的形式存储,通过双向链表对key进行排序,双向链表的每个节点内存储当前key对应的多个版本数据形成的链表,双向链表的每个节点指向内存块存储的该key对应的key-value;所述ART索引用于快速定位双向链表的特定节点,所述Hash索引用于快速查询ART树的叶子节点的地址;
写入数据时,首先通过Hash索引与ART索引计算待插入的叶子结点位置,然后根据ART的叶子节点添加双向链表,通过双向链表对业务key进行排序。
所述步骤1)中,当有新的key插入叶子节点时,使用ART算法快速定位到双向链表的插入节点进行插入,同时增加hash表的插入逻辑,对Hash表加锁;将key的String类型作为Hash表中的key,将叶子节点指针位置作为Hash表中的value插入到Hash表中。
所述步骤1)中,新建一个ART索引维护类,使用ART算法替换Memtable中的skiplist算法;在ART索引维护类中新建一个Hash索引类成员HashMap(哈希映射),用于ART索引叶节点的快速查询。
所述步骤1)中,使用PureMemRep类继承public MemtableRep,新增Memtable的内存仓库管理类,使用InlineART类替换InlinSkiplist类,用以实现基于ART算法的内存数据索引;
在InlineART类中增加类成员HashTable(hash表),hash表中存放ART叶节点和key。
所述步骤2)中,启用异步刷盘线程,维护所有内存块的队列,队列按照内存块的上次刷盘时间排序;线程从队列取内存块,并将内存块增量的kv数据(key-value)进行落盘,追加到文件末尾或形成新的磁盘SST文件。
内存块一般具有固定大小,用于存储数据库插入时传入的KV数据。按照传入的先后顺序顺序排放存储在内存块中。内存块存放满时,创建新的内存块存放新插入的KV数据。
所述步骤3)中,调用Memtable::NewIterator接口创建基于ART树的Iterator(迭代器),用于遍历ART树中的节点;
新建Memtable::NewHashIterator接口,增加ReadOptions参数,用于判断是否为MVCCGet读取;如果是则调用NewHashIterator接口,直接从Hash表中查找存储key的双向链表所对应的叶子节点,如果不是则调用NewIterator接口在hash索引中查找叶子节点,若没有再去ART索引查询;
最终得到ART树的叶子节点,得到存储多版本key的双向链表,通过遍历双向链表得到内存块中的数据(key-value)。
所述步骤3)中,当读取多版本数据即MVCCGet数据时,在Hash表中取出key对应的叶子节点,然后从叶子节点对应的双向链表中取出对应的key;如果hash索引中没有查到key,说明已经数据已经落盘,则去磁盘SST文件中查找;
当读取非MVCCGet数据时,则在hash索引中查找对应的叶子节点,若没找到对应的叶子节点,则在ART树中查找叶子节点,若ART树中没有找到对应的叶子节点,则去磁盘SST(Silicon Storage Technology,硅存储)文件中查找。
以上所述的实施例,只是本发明具体实施方式的一种,本领域的技术人员在本发明技术方案范围内进行的通常变化和替换都应包含在本发明的保护范围内。

Claims (9)

1.一种内存数据库存储引擎管理方法,其特征在于:基于RocksDB存储引擎的Memtable管理机制,在Memtable内部新建ART索引用以取代skiplist索引,采用ART索引加Hash索引的双索引机制查询key-value,优化RocksDB存储引擎的读性能,从而实现RocksDB内存引擎模式,减少磁盘读写,提高查询速度。
2.根据权利要求1所述的内存数据库存储引擎管理方法,其特征在于,具体实现过程如下:
1)将插入Memtable的数据转为插入到ART算法管理的内存块中,并将ART算法的叶节点地址加入Hash索引中;
2)修改Memtable刷盘的逻辑,使得Memtable永不转换imMemtable,通过内存块的形式进行刷盘,内存块通过双向链表进行管理;
3)执行查询操作时,先从Hash表中查询,然后查询ART树,最后查询磁盘SST文件。
3.根据权利要求2所述的内存数据库存储引擎管理方法,其特征在于:所述步骤1)中,写入的数据在内存中以内存块的形式存储,通过双向链表对key进行排序,双向链表的每个节点内存储当前key对应的多个版本数据形成的链表,双向链表的每个节点指向内存块存储的该key对应的key-value;所述ART索引用于快速定位双向链表的特定节点,所述Hash索引用于快速查询ART树的叶子节点的地址;
写入数据时,首先通过Hash索引与ART索引计算待插入的叶子结点位置,然后根据ART的叶子节点添加双向链表,通过双向链表对业务key进行排序。
4.根据权利要求3所述的内存数据库存储引擎管理方法,其特征在于:所述步骤1)中,当有新的key插入叶子节点时,使用ART算法快速定位到双向链表的插入节点进行插入,同时增加hash表的插入逻辑,对Hash表加锁;将key的String类型作为Hash表中的key,将叶子节点指针位置作为Hash表中的value插入到Hash表中。
5.根据权利要求2所述的内存数据库存储引擎管理方法,其特征在于:所述步骤1)中,新建一个ART索引维护类,使用ART算法替换Memtable中的skiplist算法;在ART索引维护类中新建一个Hash索引类成员HashMap,用于ART索引叶节点的快速查询。
6.根据权利要求5所述的内存数据库存储引擎管理方法,其特征在于:所述步骤1)中,使用PureMemRep类继承public MemtableRep,新增Memtable的内存仓库管理类,使用InlineART类替换InlinSkiplist类,用以实现基于ART算法的内存数据索引;在InlineART类中增加类成员HashTable,hash表中存放ART叶节点和key。
7.根据权利要求2所述的内存数据库存储引擎管理方法,其特征在于:所述步骤2)中,启用异步刷盘线程,维护所有内存块的队列,队列按照内存块的上次刷盘时间排序;线程从队列取内存块,并将内存块增量的kv数据进行落盘,追加到文件末尾或形成新的磁盘SST文件。
8.根据权利要求2所述的内存数据库存储引擎管理方法,其特征在于:所述步骤3)中,调用Memtable::NewIterator接口创建基于ART树的Iterator,用于遍历ART树中的节点;
新建Memtable::NewHashIterator接口,增加ReadOptions参数,用于判断是否为MVCCGet读取;如果是则调用NewHashIterator接口,直接从Hash表中查找存储key的双向链表所对应的叶子节点,如果不是则调用NewIterator接口在hash索引中查找叶子节点,若没有再去ART索引查询;
最终得到ART树的叶子节点,得到存储多版本key的双向链表,通过遍历双向链表得到内存块中的数据。
9.根据权利要求8所述的内存数据库存储引擎管理方法,其特征在于:所述步骤3)中,当读取多版本数据即MVCCGet数据时,在Hash表中取出key对应的叶子节点,然后从叶子节点对应的双向链表中取出对应的key;如果hash索引中没有查到key,说明已经数据已经落盘,则去磁盘SST文件中查找;
当读取非MVCCGet数据时,则在hash索引中查找对应的叶子节点,若没找到对应的叶子节点,则在ART树中查找叶子节点,若ART树中没有找到对应的叶子节点,则去磁盘SST文件中查找。
CN202110894627.6A 2021-08-05 2021-08-05 一种内存数据库存储引擎管理方法 Active CN113688130B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202110894627.6A CN113688130B (zh) 2021-08-05 2021-08-05 一种内存数据库存储引擎管理方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202110894627.6A CN113688130B (zh) 2021-08-05 2021-08-05 一种内存数据库存储引擎管理方法

Publications (2)

Publication Number Publication Date
CN113688130A true CN113688130A (zh) 2021-11-23
CN113688130B CN113688130B (zh) 2023-10-13

Family

ID=78578870

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202110894627.6A Active CN113688130B (zh) 2021-08-05 2021-08-05 一种内存数据库存储引擎管理方法

Country Status (1)

Country Link
CN (1) CN113688130B (zh)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114218274A (zh) * 2021-12-09 2022-03-22 浪潮云信息技术股份公司 一种基于rockadb存储引擎增大内存的方法及系统
CN114969034A (zh) * 2022-05-16 2022-08-30 北京奥星贝斯科技有限公司 LSM-Tree架构数据库有序表的查询方法和装置

Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105320775A (zh) * 2015-11-11 2016-02-10 中科曙光信息技术无锡有限公司 数据的存取方法和装置
CN108280229A (zh) * 2018-02-26 2018-07-13 腾讯科技(深圳)有限公司 内存数据读写方法和装置
CN110347336A (zh) * 2019-06-10 2019-10-18 华中科技大学 一种基于nvm与ssd混合存储结构的键值存储系统
CN112269786A (zh) * 2020-11-02 2021-01-26 浪潮云信息技术股份公司 一种内存数据库kv存储引擎索引的创建方法
CN112667644A (zh) * 2021-01-20 2021-04-16 浪潮云信息技术股份公司 一种混合索引内存数据库存储引擎管理方法
WO2021085717A1 (ko) * 2019-11-01 2021-05-06 연세대학교 산학협력단 비휘발성 메모리를 이용한 로그 구조 병합 트리 기반의 데이터 베이스의 데이터 처리 방법
KR20210052845A (ko) * 2019-11-01 2021-05-11 서울과학기술대학교 산학협력단 범용적인 데이터 저장을 위한 윈도우 운영체계에서의 저장 시스템 및 그 방법

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105320775A (zh) * 2015-11-11 2016-02-10 中科曙光信息技术无锡有限公司 数据的存取方法和装置
CN108280229A (zh) * 2018-02-26 2018-07-13 腾讯科技(深圳)有限公司 内存数据读写方法和装置
CN110347336A (zh) * 2019-06-10 2019-10-18 华中科技大学 一种基于nvm与ssd混合存储结构的键值存储系统
WO2021085717A1 (ko) * 2019-11-01 2021-05-06 연세대학교 산학협력단 비휘발성 메모리를 이용한 로그 구조 병합 트리 기반의 데이터 베이스의 데이터 처리 방법
KR20210052845A (ko) * 2019-11-01 2021-05-11 서울과학기술대학교 산학협력단 범용적인 데이터 저장을 위한 윈도우 운영체계에서의 저장 시스템 및 그 방법
CN112269786A (zh) * 2020-11-02 2021-01-26 浪潮云信息技术股份公司 一种内存数据库kv存储引擎索引的创建方法
CN112667644A (zh) * 2021-01-20 2021-04-16 浪潮云信息技术股份公司 一种混合索引内存数据库存储引擎管理方法

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
谢平: "存储系统重复数据删除技术研究综述", 计算机科学, vol. 41, no. 1, pages 22 - 30 *

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114218274A (zh) * 2021-12-09 2022-03-22 浪潮云信息技术股份公司 一种基于rockadb存储引擎增大内存的方法及系统
CN114969034A (zh) * 2022-05-16 2022-08-30 北京奥星贝斯科技有限公司 LSM-Tree架构数据库有序表的查询方法和装置

Also Published As

Publication number Publication date
CN113688130B (zh) 2023-10-13

Similar Documents

Publication Publication Date Title
US9672235B2 (en) Method and system for dynamically partitioning very large database indices on write-once tables
CN108052551B (zh) 一种在redis上实现的存储大量时序数据的方法
CN113688130B (zh) 一种内存数据库存储引擎管理方法
US20110264667A1 (en) Column-oriented storage in a row-oriented database management system
CN113821171B (zh) 一种基于哈希表与lsm树的键值存储方法
CN110888886A (zh) 一种索引结构及构建方法、键值存储系统及请求处理方法
CN105117415A (zh) 一种优化的ssd数据更新方法
CN116257523A (zh) 一种基于非易失存储器的列式存储索引方法及装置
CN109299143B (zh) 基于Redis缓存的数据互操作测试知识库的知识快速索引方法
CN112732725B (zh) 基于nvm混合内存的自适应前缀树构建方法及其系统、介质
KR102127785B1 (ko) 효율적인 인덱싱을 제공하기 위한 방법, 장치 및 컴퓨터-판독가능 매체에 포함된 컴퓨터 프로그램
Jensen et al. Optimality in external memory hashing
CN116701440A (zh) 一种布谷鸟过滤器及数据插入、查询、删除方法
CN112463837B (zh) 一种关系型数据库数据存储查询方法
CN109800233A (zh) 一种大数据融合搜索方法
CN112395440A (zh) 一种缓存方法、高效图像语义检索方法和系统
CN1235169C (zh) 一种嵌入式系统的数据存放及其查找方法
Zhang et al. Optimizing adaptive radix trees for NVM-based hybrid memory architecture
CN114741382A (zh) 一种减少读时延的缓存方法和系统
CN101458707A (zh) 一种大数据量记录的存储方法
CN113742307B (zh) 一种基于值日志系统的二级索引的存储和查询方法及系统
CN118034608A (zh) 基于b+树和wal的图形数据库读写性能优化方法
CN117349477A (zh) 一种基于持久化内存的图数据异构分层存储结构及其方法
CN114968976A (zh) 内存数据库存储引擎数据优化方法、电子设备及存储介质
KR100726300B1 (ko) 주 메모리 데이터베이스의 다차원 색인 압축 방법

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: 20221215

Address after: Room 305-22, Building 2, No. 1158 Zhangdong Road and No. 1059 Dangui Road, China (Shanghai) Pilot Free Trade Zone, Pudong New Area, Shanghai, 200120

Applicant after: Shanghai Yunxi Technology Co.,Ltd.

Address before: 250100 No. 1036 Tidal Road, Jinan High-tech Zone, Shandong Province, S01 Building, Tidal Science Park

Applicant before: Inspur cloud Information Technology Co.,Ltd.

GR01 Patent grant
GR01 Patent grant