资料介绍
软件简介
TerarkDB 是字节跳动开源的 RocksDB 的替代品,具有优化的尾部延迟、吞吐量和压缩等。在大多数情况下,你可以将现有的 RocksDB 实例迁移到 TerarkDB,没有任何问题。
- TerarkDB 仅在 Linux 平台下测试和生产就绪
- 除 C/C++ 之外的语言绑定尚未完全测试。
- 现有数据可以直接从 RocksDB 迁移到 TerarkDB,但不能迁移回 RocksDB。
- TerarkDB 是从 RocksDB v5.18.3 分支出来的
性能概览
- RocksDB v6.12
- 服务器
-
工作台工具和工作负载
-
利用
db_bench
- 10 个客户端线程,每个线程 20GB 请求
- 键 = 24 字节,值 = 2000 字节
-
heavy_write
意味着 90% 的写操作 -
heavy_read
意味着 90% 的读取操作
-
利用
用法
- 基于块的表(BlockBasedTable)
#include
#include "rocksdb/db.h"
rocksdb::DB* db;
rocksdb::Options options;
// Your options here
options.create_if_missing = true;
options.wal_bytes_per_sync = 32768;
options.bytes_per_sync = 32768;
// Open DB
auto status = rocksdb::DB::Open(options, "/tmp/testdb", &db);
// Operations
std::string value;
auto s = db->Put(rocksdb::WriteOptions(), "key1", "value1");
s = db->Get(rocksdb::ReadOptions(), "key1", &value);
assert(s.ok());
assert("value1" == value);
s = db->Delete(rocksdb::WriteOptions(), "key1");
assert(s.ok());
或手动设置表格格式和表格选项:
#include
#include "rocksdb/db.h"
#include "rocksdb/options.h"
#include "rocksdb/table.h"
rocksdb::DB* db;
rocksdb::Options options;
// Your db options here
options.create_if_missing = true;
options.wal_bytes_per_sync = 32768;
options.bytes_per_sync = 32768;
// Manually specify target table and table options
rocksdb::BlockBasedTableOptions table_options;
table_options.block_cache =
rocksdb::NewLRUCache(32ULL << 30, 8, false);
table_options.block_size = 8ULL << 10;
options.table_factory = std::shared_ptr
(NewBlockBasedTableFactory(table_options));
// Open DB
auto status = rocksdb::DB::Open(options, "/tmp/testdb2", &db);
// Operations
std::string value;
auto s = db->Put(rocksdb::WriteOptions(), "key1", "value1");
s = db->Get(rocksdb::ReadOptions(), "key1", &value);
assert(s.ok());
assert("value1" == value);
s = db->Delete(rocksdb::WriteOptions(), "key1");
assert(s.ok());
- Terark 压缩表格(TerarkZipTable)
#include
#include "rocksdb/db.h"
#include "rocksdb/options.h"
#include "rocksdb/table.h"
#include "table/terark_zip_table.h"
rocksdb::DB* db;
rocksdb::Options options;
// Your db options here
options.create_if_missing = true;
options.wal_bytes_per_sync = 32768;
options.bytes_per_sync = 32768;
// TerarkZipTable need a `fallback` options because you can indicate which LSM level you want to start using TerarkZipTable
// For example, by setting tzt_options.terarkZipMinLevel = 2, TerarkDB will use your fallback Table on level 0 and 1.
std::shared_ptr table_factory;
rocksdb::BlockBasedTableOptions blockbased_options;
blockbased_options.block_size = 8ULL << 10;
table_factory.reset(NewBlockBasedTableFactory(blockbased_options));
rocksdb::TerarkZipTableOptions tzt_options;
// TerarkZipTable requires a temp directory other than data directory, a slow device is acceptable
tzt_options.localTempDir = "/tmp";
tzt_options.indexNestLevel = 3;
tzt_options.sampleRatio = 0.01;
tzt_options.terarkZipMinLevel = 2; // Start using TerarkZipTable from level 2
table_factory.reset(
rocksdb::NewTerarkZipTableFactory(tzt_options, table_factory));
options.table_factory = table_factory;
// Open DB
auto status = rocksdb::DB::Open(options, "/tmp/testdb2", &db);
// Operations
std::string value;
auto s = db->Put(rocksdb::WriteOptions(), "key1", "value1");
s = db->Get(rocksdb::ReadOptions(), "key1", &value);
assert(s.ok());
assert("value1" == value);
s = db->Delete(rocksdb::WriteOptions(), "key1");
assert(s.ok());
实际性能改进
TerarkDB 已经部署在字节跳动的许多应用程序中,在大多数情况下,TerarkDB 可以帮助减少延迟峰值并极大地提高吞吐量。
磁盘写入(Disk Write)
获取延迟(Get Latency )
下载该资料的人也在下载
下载该资料的人还在阅读
更多 >
- 35KV户内六氟化硫SF6断路器
- 150W经典应用电路-过雷击浪涌6KV电路图 65次下载
- DL/T5103-201230kV~220kV无人值守变电站设计技术规程
- 医疗行业的电磁兼容试验标准总结 23次下载
- 电磁兼容试验和测量技术抗扰试验综述 39次下载
- 基于FPGA块存储器的多位反转容错 19次下载
- 接收机在软件定义无线电中的电磁兼容问题 12次下载
- USB 3.0存储发展历史及展望综述 42次下载
- 基于Unity3D游戏引擎的神经反馈治疗系统 5次下载
- 基于DSP的35Kv电网故障监测系统 16次下载
- 汽车电磁兼容发展状况如何?汽车电磁兼容未来发展的趋势如何? 25次下载
- ATECC508A加密引擎身份验证器件的详细中文数据手册
- dsPIC33和PIC24 FRM上的加密引擎的详细中文资料概述
- 引擎是什么意思?引擎的保养方法 4次下载
- 架空输电线路运行规范110(66)kV~500kV
- 35kv变压器容量有哪些规格型号 1w次阅读
- 10kV防止开关跳跃原理 456次阅读
- 浅析openEuler Cantian引擎 1230次阅读
- 持久化数据到硬盘上并采用RocksDB作为存储引擎 1213次阅读
- 如何用Rust构建一个KV Server系列 1244次阅读
- 大数据生态系统最底层的数据存储 3444次阅读
- 企业存储系统停机事故怎样避免出现 642次阅读
- 某医疗器械的电磁兼容性电路优化改进方案 1719次阅读
- 10kV高压开关柜的构成_10kV高压开关柜交直流回路 1.4w次阅读
- DCS存储控制系统将成为浪潮高端存储的核心引擎 979次阅读
- 怎样选择存储引擎?MySQL存储引擎怎么样? 4566次阅读
- MySQL存储引擎中MyISAM与InnoDB优劣势比较分析 2615次阅读
- 数据库引擎是什么 1.1w次阅读
- 常用的数据库引擎有哪些_数据库引擎分类 2.1w次阅读
- 垂直搜索引擎是什么_垂直搜索引擎有哪些 7790次阅读
下载排行
本周
- 1山景DSP芯片AP8248A2数据手册
- 1.06 MB | 532次下载 | 免费
- 2RK3399完整板原理图(支持平板,盒子VR)
- 3.28 MB | 339次下载 | 免费
- 3TC358743XBG评估板参考手册
- 1.36 MB | 330次下载 | 免费
- 4DFM软件使用教程
- 0.84 MB | 295次下载 | 免费
- 5元宇宙深度解析—未来的未来-风口还是泡沫
- 6.40 MB | 227次下载 | 免费
- 6迪文DGUS开发指南
- 31.67 MB | 194次下载 | 免费
- 7元宇宙底层硬件系列报告
- 13.42 MB | 182次下载 | 免费
- 8FP5207XR-G1中文应用手册
- 1.09 MB | 178次下载 | 免费
本月
- 1OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234315次下载 | 免费
- 2555集成电路应用800例(新编版)
- 0.00 MB | 33566次下载 | 免费
- 3接口电路图大全
- 未知 | 30323次下载 | 免费
- 4开关电源设计实例指南
- 未知 | 21549次下载 | 免费
- 5电气工程师手册免费下载(新编第二版pdf电子书)
- 0.00 MB | 15349次下载 | 免费
- 6数字电路基础pdf(下载)
- 未知 | 13750次下载 | 免费
- 7电子制作实例集锦 下载
- 未知 | 8113次下载 | 免费
- 8《LED驱动电路设计》 温德尔著
- 0.00 MB | 6656次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935054次下载 | 免费
- 2protel99se软件下载(可英文版转中文版)
- 78.1 MB | 537798次下载 | 免费
- 3MATLAB 7.1 下载 (含软件介绍)
- 未知 | 420027次下载 | 免费
- 4OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234315次下载 | 免费
- 5Altium DXP2002下载入口
- 未知 | 233046次下载 | 免费
- 6电路仿真软件multisim 10.0免费下载
- 340992 | 191187次下载 | 免费
- 7十天学会AVR单片机与C语言视频教程 下载
- 158M | 183279次下载 | 免费
- 8proe5.0野火版下载(中文版免费下载)
- 未知 | 138040次下载 | 免费
评论
查看更多