RocksDB参数调优

一、前言

本文创作于2017.2.15,当时使用的RocksDB版本为4.9。所测数据只能反映当时版本的性能,不适用于如今的新版本。
本文主要研究基于不同参数的调优,来展示对性能的影响,以供读者参考,提供优化的思路和方向。

二、RocksDB关键性能指标

本篇文章,主要利用了RocksDB的benchmark机制,进行各项测试。检测它的读写性能,以及各个参数调优后对性能的提升。
RocksDB中,可以调整的参数非常多,很多都是可以配置的,不同于LevelDB,需要修改代码,重新打包。
RocksDB的调优,主要就是为了优化下面的3种对性能有很大影响的场景:

1. 写放大

写放大即:写磁盘的速率 / 写数据的速率。
举个例子:如果写数据库速率为10Mb/s,磁盘写速率可以支持50Mb/s,则写放大为5。
也就是说,如果磁盘最大支持50Mb/s的写入,并且写放大为5,则意味着数据库所能支持的写入速率为10Mb/s。
在这种情况下,减小写放大倍数,可以显著增加数据库的写吞吐量。

2. 读放大

读放大即:做一次查询,需要进行读磁盘的次数。
如果做一次查询,需要读5次page,则读放大倍数为5。
其中,读数据分为逻辑读(logical read)和物理读(physical read)。逻辑读通常是对cache进行读取,RocksDB中,cache分为block cache 和table cache, 同时,os也有page cache。Block cache存储的是未压缩的block data,而page cache存储的是压缩过的block data。物理读就是直接读磁盘。

3. 空间放大

空间放大即:数据库文件大小 / 原始数据大小
例如:如果将10MB的数据存入数据库,而最终数据库占用了100MB的磁盘,则空间放大倍

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

水草

您的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值