文章目录
一、前言
本文创作于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的磁盘,则空间放大倍