LevelDB (1)概述
生活随笔
收集整理的這篇文章主要介紹了
LevelDB (1)概述
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1. LevelDB
非常高效的kv數據庫,能夠支持billion級別的數據量了。 在這個數量級別下還有著非常高的性能,主要歸功于它的良好的設計。特別是LSM算法。
LevelDB 是單進程的服務,性能非常之高,在一臺4個Q6600的CPU機器上,每秒鐘寫數據超過40w,而隨機讀的性能每秒鐘超過10w。此處隨機讀是完全命中內存的速度,如果是不命中,速度大大下降。
eg.
#include "leveldb/include/db.h"leveldb::DB* db; leveldb::Options options; options.create_if_missing = true; leveldb::Status status = leveldb::DB::Open(options, "/tmp/testdb", &db); assert(status.ok());std::string value; leveldb::Status s = db->Get(leveldb::ReadOptions(), key1, &value); if (s.ok()) s = db->Put(leveldb::WriteOptions(), key2, value); if (s.ok()) s = db->Delete(leveldb::WriteOptions(), key1);eg2.
#include "leveldb/db.h" #include <iostream>using namespace std;int main(){leveldb::DB *db;leveldb::Options options;options.create_if_missing = true;// 開啟數據庫leveldb::DB::Open(options, "/tmp/testdb", &db);// 鍵 = MyKey29,值 = "Hello World!"string key = "MyKey29", value = "Hello World!", result;// 儲存 鍵/值對db->Put(leveldb::WriteOptions(), key, value);// 查詢 MyKey29 鍵的值db->Get(leveldb::ReadOptions(), key, &result);// 輸出值到屏幕cout << "result = " << result << endl;// 關閉數據庫delete db;return 0; }總結
以上是生活随笔為你收集整理的LevelDB (1)概述的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: stdthread(9)死锁deadlo
- 下一篇: c++新特性11 (6) =defaul