RocksDB Tombstone 详解

本文详细介绍了RocksDB中Tombstone的概念、使用场景和原理,包括删除操作如何利用Tombstone提高效率,以及查询时的处理方式。同时探讨了RocksDB在Tombstone上的优化策略。
摘要由CSDN通过智能技术生成

目录

为什么会有墓碑?

使用场景

原理

描述

 分段

查询

优化点

总结


为什么会有墓碑?

        我们知道 TP 数据库一般选择 KV 引擎作为存储引擎,数据库的元数据和数据通过一定的编码规则变成 KV 对存储在存储引擎中,比如 CockroachDB 数据库的编码前缀规则如下。

/Local/… =>   节点本地数据
/Meta1/… =>   一级路由数据
/Meta2/… =>   二级路由数据
/System/… =>  系统数据
/Table/… =>   表数据

        我们拿 Table 数据作为例子,表数据划分为系统表数据和用户表数据。用户完成建表和数据插入后,CockroachDB 内部的 SQL-KV 转换模型会将用户表数据转换成一系列 KV 对,按照 Key 顺序存储在存储引擎中。KV 对分为以 Primary Key 为前缀和以Index(二级索引)为前缀的编码,其中以 Primary Key 为前缀的 KV 对存储了用户表的实际数据。

主键索引编码规则:

// Key 编码
/Table/<id>/<index>/<pk val>/<family>

Table:表示为行数据的前缀
<id>:表示表 ID
<index>:表示主索引ID
<pk val>:表示主索引的值
<family>:表示列族ID。没有建列族默认为 0

// Value 编码
<crc><type>/TUPLE/colIDDiff:colID:type/val/../colIDDiff:colID:t
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值