區(qū)塊鏈常用數(shù)據(jù)庫leveldb用java來實現(xiàn)常規(guī)操作的方法
前言
LevelDB 是一種Key-Value存儲數(shù)據(jù)庫百度百科上介紹 性能非常強悍 可以支撐十億級這段時間在研究區(qū)塊鏈的時候發(fā)現(xiàn)的這個數(shù)據(jù)庫。LevelDB 是單進程的服務(wù),性能非常之高,在一臺4核Q6600的CPU機器上,每秒鐘寫數(shù)據(jù)超過40w,而隨機讀的性能每秒鐘超過10w。 此處隨機讀是完全命中內(nèi)存的速度,如果是不命中 速度大大下降,LevelDB 只是一個 C/C++ 編程語言的庫, 不包含網(wǎng)絡(luò)服務(wù)封裝, 所以無法像一般意義的存儲服務(wù)器(如 MySQL)那樣, 用客戶端來連接它. LevelDB 自己也聲明, 使用者應(yīng)該封裝自己的網(wǎng)絡(luò)服務(wù)器.
引入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存儲都是字節(jié)數(shù)組 所以這里需要轉(zhuǎn)成字節(jié)數(shù)組 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));
遍歷所有數(shù)據(jù)
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;
}
測試插入一百萬條數(shù)據(jù)
基于SpringBoot搭建的控制器
隨機生成 指定數(shù)量的UUID 并且插入到LevelDB
從請求 到響應(yīng) 5.5秒左右 如果再拋掉生成UUID的時間 可能更快 哈哈
@ResponseBody
@GetMapping("/generate")
public ResponeEntity generate(Long count) {
DB db = levelDb.getDb();
//創(chuàng)建批量處理
WriteBatch batch = db.createWriteBatch();
for (int i = 0; i < count; i++) {
String uuid = UUID.randomUUID().toString();
batch.put(Iq80DBFactory.bytes(uuid), Iq80DBFactory.bytes(uuid));
}
//執(zhí)行寫入
db.write(batch);
return buildRespone(null);
}

測試從一百萬數(shù)據(jù)中取出一條
PostMan 請求到響應(yīng)時間 19毫秒
@ResponseBody
@GetMapping("/getLevel")
public ResponeEntity getLevel(String key) {
byte[] bytes = db.get(Iq80DBFactory.bytes(key));
String value = Iq80DBFactory.asString(bytes);
return buildRespone(value);
}

到此這篇關(guān)于區(qū)塊鏈常用數(shù)據(jù)庫leveldb用java來實現(xiàn)常規(guī)操作的文章就介紹到這了,更多相關(guān)區(qū)塊鏈常用數(shù)據(jù)庫leveldb用java來實現(xiàn)常規(guī)操作內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
一文搞懂并學(xué)會使用SpringBoot的Actuator運行狀態(tài)監(jiān)控組件的詳細教程
這篇文章主要介紹了一文搞懂并學(xué)會使用SpringBoot的Actuator運行狀態(tài)監(jiān)控組件,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09
SpringBoot實現(xiàn)的Mongodb管理工具使用解析
這篇文章主要介紹了SpringBoot實現(xiàn)的Mongodb管理工具使用解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-09-09
Java多線程并發(fā)的指令重排序問題及volatile寫屏障原理詳解
這篇文章主要介紹了Java多線程并發(fā)的指令重排序問題及volatile寫屏障原理詳解,指令重排序是編譯器或處理器為了提高性能而對指令執(zhí)行順序進行重新排列的優(yōu)化技術(shù),需要的朋友可以參考下2024-01-01
Java組件FileUpload上傳文件實現(xiàn)代碼
這篇文章主要為大家詳細介紹了Java組件FileUpload上傳文件實現(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-06-06
SpringBoot 如何使用Dataway配置數(shù)據(jù)查詢接口
這篇文章主要介紹了SpringBoot 如何使用Dataway配置數(shù)據(jù)查詢接口,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11

