區(qū)塊鏈常用數(shù)據(jù)庫leveldb用java來實(shí)現(xiàn)常規(guī)操作的方法
LevelDB 是一種Key-Value存儲(chǔ)數(shù)據(jù)庫百度百科上介紹 性能非常強(qiáng)悍 可以支撐十億級這段時(shí)間在研究區(qū)塊鏈的時(shí)候發(fā)現(xiàn)的這個(gè)數(shù)據(jù)庫。LevelDB 是單進(jìn)程的服務(wù),性能非常之高,在一臺(tái)4核Q6600的CPU機(jī)器上,每秒鐘寫數(shù)據(jù)超過40w,而隨機(jī)讀的性能每秒鐘超過10w。 此處隨機(jī)讀是完全命中內(nèi)存的速度,如果是不命中 速度大大下降,LevelDB 只是一個(gè) C/C++ 編程語言的庫, 不包含網(wǎng)絡(luò)服務(wù)封裝, 所以無法像一般意義的存儲(chǔ)服務(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存儲(chǔ)目錄DB db = factory.open(new File(folder), options);
存儲(chǔ)Key Value 值
//levelDB 的api存儲(chǔ)都是字節(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搭建的控制器
隨機(jī)生成 指定數(shù)量的UUID 并且插入到LevelDB
從請求 到響應(yīng) 5.5秒左右 如果再拋掉生成UUID的時(shí)間 可能更快 哈哈
@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); }
PostMan 請求到響應(yīng)時(shí)間 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來實(shí)現(xiàn)常規(guī)操作的文章就介紹到這了,更多相關(guān)區(qū)塊鏈常用數(shù)據(jù)庫leveldb用java來實(shí)現(xiàn)常規(guī)操作內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. XML解析錯(cuò)誤:未組織好 的解決辦法2. asp批量添加修改刪除操作示例代碼3. JSP數(shù)據(jù)交互實(shí)現(xiàn)過程解析4. ASP腳本組件實(shí)現(xiàn)服務(wù)器重啟5. PHP字符串前后字符或空格刪除方法介紹6. Properties 持久的屬性集的實(shí)例詳解7. 三個(gè)不常見的 HTML5 實(shí)用新特性簡介8. IE6/IE7/IE8/IE9中tbody的innerHTML不能賦值的完美解決方案9. 使用Spry輕松將XML數(shù)據(jù)顯示到HTML頁的方法10. PHP循環(huán)與分支知識(shí)點(diǎn)梳理
