區塊鏈常用數據庫leveldb用java來實現常規操作的方法
前言
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); }
到此這篇關於區塊鏈常用數據庫leveldb用java來實現常規操作的文章就介紹到這瞭,更多相關區塊鏈常用數據庫leveldb用java來實現常規操作內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- java操作excel表格詳解
- java利用pdfbox+poi往pdf插入數據
- Java aop面向切面編程(aspectJweaver)案例詳解
- 在SSM框架中將圖片上傳到數據庫中的實現代碼
- 深入淺析Java常用的格式化Json工具類