資料介紹
軟件簡(jiǎn)介
TerarkDB 是字節(jié)跳動(dòng)開(kāi)源的?RocksDB 的替代品,具有優(yōu)化的尾部延遲、吞吐量和壓縮等。在大多數(shù)情況下,你可以將現(xiàn)有的 RocksDB 實(shí)例遷移到 TerarkDB,沒(méi)有任何問(wèn)題。
- TerarkDB 僅在 Linux 平臺(tái)下測(cè)試和生產(chǎn)就緒
- 除 C/C++ 之外的語(yǔ)言綁定尚未完全測(cè)試。
- 現(xiàn)有數(shù)據(jù)可以直接從 RocksDB 遷移到 TerarkDB,但不能遷移回 RocksDB。
- TerarkDB 是從 RocksDB v5.18.3 分支出來(lái)的
性能概覽
- RocksDB v6.12
- 服務(wù)器
-
工作臺(tái)工具和工作負(fù)載
-
利用?
db_bench
- 10 個(gè)客戶端線程,每個(gè)線程 20GB 請(qǐng)求
- 鍵 = 24 字節(jié),值 = 2000 字節(jié)
-
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());
或手動(dòng)設(shè)置表格格式和表格選項(xiàng):
#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());
實(shí)際性能改進(jìn)
TerarkDB 已經(jīng)部署在字節(jié)跳動(dòng)的許多應(yīng)用程序中,在大多數(shù)情況下,TerarkDB 可以幫助減少延遲峰值并極大地提高吞吐量。
磁盤寫入(Disk Write)
獲取延遲(Get Latency?)
- 35KV戶內(nèi)六氟化硫SF6斷路器
- 150W經(jīng)典應(yīng)用電路-過(guò)雷擊浪涌6KV電路圖 65次下載
- DL/T5103-201230kV~220kV無(wú)人值守變電站設(shè)計(jì)技術(shù)規(guī)程
- 醫(yī)療行業(yè)的電磁兼容試驗(yàn)標(biāo)準(zhǔn)總結(jié) 23次下載
- 電磁兼容試驗(yàn)和測(cè)量技術(shù)抗擾試驗(yàn)綜述 39次下載
- 基于FPGA塊存儲(chǔ)器的多位反轉(zhuǎn)容錯(cuò) 19次下載
- 接收機(jī)在軟件定義無(wú)線電中的電磁兼容問(wèn)題 12次下載
- USB 3.0存儲(chǔ)發(fā)展歷史及展望綜述 42次下載
- 基于Unity3D游戲引擎的神經(jīng)反饋治療系統(tǒng) 5次下載
- 基于DSP的35Kv電網(wǎng)故障監(jiān)測(cè)系統(tǒng) 16次下載
- 汽車電磁兼容發(fā)展?fàn)顩r如何?汽車電磁兼容未來(lái)發(fā)展的趨勢(shì)如何? 25次下載
- ATECC508A加密引擎身份驗(yàn)證器件的詳細(xì)中文數(shù)據(jù)手冊(cè)
- dsPIC33和PIC24 FRM上的加密引擎的詳細(xì)中文資料概述
- 引擎是什么意思?引擎的保養(yǎng)方法 4次下載
- 架空輸電線路運(yùn)行規(guī)范110(66)kV~500kV
- 35kv變壓器容量有哪些規(guī)格型號(hào) 1w次閱讀
- 10kV防止開(kāi)關(guān)跳躍原理 456次閱讀
- 淺析openEuler Cantian引擎 1230次閱讀
- 持久化數(shù)據(jù)到硬盤上并采用RocksDB作為存儲(chǔ)引擎 1213次閱讀
- 如何用Rust構(gòu)建一個(gè)KV Server系列 1244次閱讀
- 大數(shù)據(jù)生態(tài)系統(tǒng)最底層的數(shù)據(jù)存儲(chǔ) 3444次閱讀
- 企業(yè)存儲(chǔ)系統(tǒng)停機(jī)事故怎樣避免出現(xiàn) 642次閱讀
- 某醫(yī)療器械的電磁兼容性電路優(yōu)化改進(jìn)方案 1719次閱讀
- 10kV高壓開(kāi)關(guān)柜的構(gòu)成_10kV高壓開(kāi)關(guān)柜交直流回路 1.4w次閱讀
- DCS存儲(chǔ)控制系統(tǒng)將成為浪潮高端存儲(chǔ)的核心引擎 979次閱讀
- 怎樣選擇存儲(chǔ)引擎?MySQL存儲(chǔ)引擎怎么樣? 4566次閱讀
- MySQL存儲(chǔ)引擎中MyISAM與InnoDB優(yōu)劣勢(shì)比較分析 2615次閱讀
- 數(shù)據(jù)庫(kù)引擎是什么 1.1w次閱讀
- 常用的數(shù)據(jù)庫(kù)引擎有哪些_數(shù)據(jù)庫(kù)引擎分類 2.1w次閱讀
- 垂直搜索引擎是什么_垂直搜索引擎有哪些 7790次閱讀
下載排行
本周
- 1山景DSP芯片AP8248A2數(shù)據(jù)手冊(cè)
- 1.06 MB | 532次下載 | 免費(fèi)
- 2RK3399完整板原理圖(支持平板,盒子VR)
- 3.28 MB | 339次下載 | 免費(fèi)
- 3TC358743XBG評(píng)估板參考手冊(cè)
- 1.36 MB | 330次下載 | 免費(fèi)
- 4DFM軟件使用教程
- 0.84 MB | 295次下載 | 免費(fèi)
- 5元宇宙深度解析—未來(lái)的未來(lái)-風(fēng)口還是泡沫
- 6.40 MB | 227次下載 | 免費(fèi)
- 6迪文DGUS開(kāi)發(fā)指南
- 31.67 MB | 194次下載 | 免費(fèi)
- 7元宇宙底層硬件系列報(bào)告
- 13.42 MB | 182次下載 | 免費(fèi)
- 8FP5207XR-G1中文應(yīng)用手冊(cè)
- 1.09 MB | 178次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 2555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33566次下載 | 免費(fèi)
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費(fèi)
- 4開(kāi)關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21549次下載 | 免費(fèi)
- 5電氣工程師手冊(cè)免費(fèi)下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費(fèi)
- 6數(shù)字電路基礎(chǔ)pdf(下載)
- 未知 | 13750次下載 | 免費(fèi)
- 7電子制作實(shí)例集錦 下載
- 未知 | 8113次下載 | 免費(fèi)
- 8《LED驅(qū)動(dòng)電路設(shè)計(jì)》 溫德?tīng)栔?/a>
- 0.00 MB | 6656次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537798次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420027次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191187次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
- 158M | 183279次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138040次下載 | 免費(fèi)
評(píng)論
查看更多