資料介紹
軟件簡介
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?)
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 150W經典應用電路-過雷擊浪涌6KV電路圖 68次下載
- DL/T5103-201230kV~220kV無人值守變電站設計技術規程
- 醫療行業的電磁兼容試驗標準總結 23次下載
- 電磁兼容試驗和測量技術抗擾試驗綜述 40次下載
- 基于FPGA塊存儲器的多位反轉容錯 19次下載
- 接收機在軟件定義無線電中的電磁兼容問題 12次下載
- USB 3.0存儲發展歷史及展望綜述 42次下載
- 基于Unity3D游戲引擎的神經反饋治療系統 5次下載
- 基于DSP的35Kv電網故障監測系統 16次下載
- 汽車電磁兼容發展狀況如何?汽車電磁兼容未來發展的趨勢如何? 26次下載
- ATECC508A加密引擎身份驗證器件的詳細中文數據手冊
- dsPIC33和PIC24 FRM上的加密引擎的詳細中文資料概述
- 引擎是什么意思?引擎的保養方法 4次下載
- 索尼KV-EF29M31/索尼KV-EF29M61/索尼KV
- 架空輸電線路運行規范110(66)kV~500kV
- 35kv變壓器容量有哪些規格型號 1.5w次閱讀
- 10kV防止開關跳躍原理 615次閱讀
- 淺析openEuler Cantian引擎 1470次閱讀
- 持久化數據到硬盤上并采用RocksDB作為存儲引擎 1358次閱讀
- 如何用Rust構建一個KV Server系列 1346次閱讀
- 大數據生態系統最底層的數據存儲 3582次閱讀
- 企業存儲系統停機事故怎樣避免出現 662次閱讀
- 某醫療器械的電磁兼容性電路優化改進方案 1802次閱讀
- 10kV高壓開關柜的構成_10kV高壓開關柜交直流回路 1.5w次閱讀
- DCS存儲控制系統將成為浪潮高端存儲的核心引擎 1060次閱讀
- 怎樣選擇存儲引擎?MySQL存儲引擎怎么樣? 4793次閱讀
- MySQL存儲引擎中MyISAM與InnoDB優劣勢比較分析 2713次閱讀
- 數據庫引擎是什么 1.1w次閱讀
- 常用的數據庫引擎有哪些_數據庫引擎分類 2.1w次閱讀
- 垂直搜索引擎是什么_垂直搜索引擎有哪些 7943次閱讀
下載排行
本周
- 1涂鴉各WiFi模塊原理圖加PCB封裝
- 11.75 MB | 76次下載 | 1 積分
- 2錦銳科技CA51F2 SDK開發包
- 24.06 MB | 29次下載 | 1 積分
- 3錦銳CA51F005 SDK開發包
- 19.47 MB | 3次下載 | 1 積分
- 4蘋果iphone 11電路原理圖
- 4.98 MB | 3次下載 | 2 積分
- 5基礎模擬電子電路
- 3.80 MB | 3次下載 | 1 積分
- 6RA-Eco-RA6M4-100PIN-V1.0開發板資料
- 34.89 MB | 1次下載 | 免費
- 7STM32F3系列、STM32F4系列、STM32L4系列和STM32L4+系列Cortex-M4編程手冊
- 3.32 MB | 1次下載 | 免費
- 8聯想A820t手機維修圖紙包括主板原理圖 尾板原理圖 點位圖
- 0.62 MB | 次下載 | 5 積分
本月
- 1AI智能眼鏡產業鏈分析
- 4.43 MB | 383次下載 | 免費
- 2蘇泊爾電磁爐線路的電路原理圖資料合集
- 2.02 MB | 296次下載 | 5 積分
- 3貼片三極管上的印字與真實名稱的對照表詳細說明
- 0.50 MB | 94次下載 | 1 積分
- 4長虹液晶電視R-HS310B-5HF01的電源板電路原理圖
- 0.46 MB | 91次下載 | 5 積分
- 5涂鴉各WiFi模塊原理圖加PCB封裝
- 11.75 MB | 76次下載 | 1 積分
- 6錦銳科技CA51F2 SDK開發包
- 24.06 MB | 29次下載 | 1 積分
- 7AO4803A雙P通道增強型場效應晶體管的數據手冊
- 0.11 MB | 28次下載 | 2 積分
- 8長虹液晶彩電LS29機芯的技術資料說明
- 3.42 MB | 16次下載 | 2 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935127次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關降壓/升壓雙向直流/直流轉換器 PCB layout 設計
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233089次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費下載
- 340992 | 191388次下載 | 10 積分
- 5十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183342次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81588次下載 | 10 積分
- 7Keil工具MDK-Arm免費下載
- 0.02 MB | 73815次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65988次下載 | 10 積分
評論