rockdb 源码解析:Log文件结构 (仅供参考)

本文详细解析了RockDB的Log文件结构,包括Blocksize、Record记录格式及写入流程。Log文件的每个Record包含CRC校验、Size、Type和Payload,写入时依据空间判断使用不同类型进行存储。Reader通过SkipToInitialBlock和ReadPhysicalRecord解析并读取Record。LogBuffer类用于缓存Log项并在合适时机flush到日志文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

       
                     Log文件结构
Log文件格式:
Blocksize=32kb
 
 
rn :代表不同长度的record
P:代表填充,当一个block剩余的空间不足以放下一个新的record时,剩下的空间会用  \0填充,空的record最短长度为7B,当剩余空间恰好为7B时,Writer发出一个first record填满剩余空间,并告知所有的用户数据在下一个新的block
Kheadersize=4+2+1=7,空record最短为7B
 
 
Record记录格式:
 
CRC:32位是有效负载的校验值
Size:16位,有效数据的长度
Type:record的类型,
  Kzerotype=0:为预配置文件的保留类型
  kFullType=1:表示record记录是完整的
kFirstType=2:record被拆分存储的第一个碎片
kMiddleType=3: record被拆分存储的其余碎片
kLastType=4:record被拆分存储的第一个碎片
Payload:有效数据,大小由size可知  
 
 Log的写入情况为:
当要写入一条首先判断当前block中是否足够存放该条日志
      S1.如果足够那么直接安装格式写入;
      S2.如果不够那么计算出去头以外可以存放多少内容,将内容组装为FIRST的Log typpe写入;然后新取一个块判断是否足够存放剩下的日志数据
       while(数据未写完)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值