av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

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

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

瀏覽:46日期: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
相關文章:
主站蜘蛛池模板: 超碰成人福利 | 日本韩国欧美中文字幕 | 国产小视频在线观看 | 亚洲天堂影院 | 欧美在线播放视频 | 日本色视频 | 中文字幕av一区 | 性色在线| 日日操av| 亚洲国产精品久久久久 | 国产日韩在线播放 | 成年人毛片 | 三级网站在线播放 | 国产中文字幕在线播放 | 激情久久网 | 噜噜视频 | 亚洲免费二区 | 黄色片在线免费观看 | 欧美jizz19性欧美 | 国产精品剧情 | 久久久黄色片 | 六月婷婷综合 | 亚洲午夜在线 | 网站av| 韩日精品视频 | av女优天堂 | 理论片中文字幕 | 美日韩一区二区 | 四虎黄色影院 | 免费看黄色一级片 | 精品久久久久久久久久久久久久久久 | 免费在线观看av | 蜜臀99久久精品久久久久小说 | a在线免费观看 | 免费视频成人 | 久久午夜影院 | 亚洲视频中文字幕 | 四虎海外 | 91黄视频 | 久久久天堂国产精品女人 | 老司机午夜免费精品视频 |