前言
LevelDB 是一種Key-Value存盤資料庫百度百科上介紹 性能非常強悍 可以支撐十億級這段時間在研究區塊鏈的時候發現的這個資料庫,LevelDB 是單行程的服務,性能非常之高,在一臺4核Q6600的CPU機器上,每秒鐘寫資料超過40w,而隨機讀的性能每秒鐘超過10w, 此處隨機讀是完全命中記憶體的速度,如果是不命中 速度大大下降,LevelDB 只是一個 C/C++ 編程語言的庫, 不包含網路服務封裝, 所以無法像一般意義的存盤服務器(如 MySQL)那樣, 用客戶端來連接它. LevelDB 自己也宣告, 使用者應該封裝自己的網路服務器.
引入SDK
<dependency>
<groupId>org.iq80.leveldb</groupId>
<artifactId>leveldb-api</artifactId>
<version>0.10</version>
</dependency>
<dependency>
<groupId>org.iq80.leveldb</groupId>
<artifactId>leveldb</artifactId>
<version>0.10</version>
</dependency>
初始化DB
DBFactory factory = new Iq80DBFactory();
Options options = new Options();
options.createIfMissing(true);
//folder 是db存盤目錄
DB db = factory.open(new File(folder), options);
存盤Key Value 值
//levelDB 的api存盤都是位元組陣列 所以這里需要轉成位元組陣列
db.put(Iq80DBFactory.bytes(key), Iq80DBFactory.bytes(value));
獲取Value
byte[] bytes = db.get(Iq80DBFactory.bytes(key));
String value = Iq80DBFactory.asString(bytes);
洗掉|更改
//洗掉
db.delete(Iq80DBFactory.bytes(key));
//更改 重新put新的key - value即可
db.put(Iq80DBFactory.bytes(key), Iq80DBFactory.bytes(value));
遍歷所有資料
public LinkedHashMap<String, String> iteratorDb() {
DBIterator iterator = db.iterator();
LinkedHashMap<String, String> linkedHashMap = new LinkedHashMap<>();
while (iterator.hasNext()) {
Map.Entry<byte[], byte[]> next = iterator.next();
String key = Iq80DBFactory.asString(next.getKey());
String value = Iq80DBFactory.asString(next.getValue());
linkedHashMap.put(key, value);
}
return linkedHashMap;
}
測驗插入一百萬條資料
基于SpringBoot搭建的控制器
隨機生成 指定數量的UUID 并且插入到LevelDB
從請求 到回應 5.5秒左右 如果再拋掉生成UUID的時間 可能更快 哈哈
@ResponseBody
@GetMapping("/generate")
public ResponeEntity generate(Long count) {
DB db = levelDb.getDb();
//創建批量處理
WriteBatch batch = db.createWriteBatch();
for (int i = 0; i < count; i++) {
String uuid = UUID.randomUUID().toString();
batch.put(Iq80DBFactory.bytes(uuid), Iq80DBFactory.bytes(uuid));
}
//執行寫入
db.write(batch);
return buildRespone(null);
}

測驗從一百萬資料中取出一條
PostMan 請求到回應時間 19毫秒
@ResponseBody
@GetMapping("/getLevel")
public ResponeEntity getLevel(String key) {
byte[] bytes = db.get(Iq80DBFactory.bytes(key));
String value = Iq80DBFactory.asString(bytes);
return buildRespone(value);
}

轉載請註明出處,本文鏈接:https://www.uj5u.com/qukuanlian/255952.html
標籤:區塊鏈
上一篇:密碼學系列 - 雙線性對
