国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

區塊鏈常用數據庫leveldb用java來實現常規操作的方法

瀏覽:38日期:2022-08-17 13:05:48
前言

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); }

區塊鏈常用數據庫leveldb用java來實現常規操作的方法

測試從一百萬數據中取出一條

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來實現常規操作的文章就介紹到這了,更多相關區塊鏈常用數據庫leveldb用java來實現常規操作內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
主站蜘蛛池模板: 彭州市| 宜州市| 湖南省| 巴林右旗| 新龙县| 漳州市| 尉犁县| 嘉义市| 北辰区| 镇江市| 任丘市| 深泽县| 蓬安县| 禹州市| 龙山县| 鞍山市| 望城县| 台州市| 铅山县| 碌曲县| 白城市| 内丘县| 闵行区| 太和县| 丹阳市| 密山市| 娄烦县| 仪征市| 晴隆县| 万载县| 高州市| 尚义县| 常熟市| 连州市| 庆城县| 绥化市| 资溪县| 龙口市| 长治县| 静乐县| 阿坝县|