久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

區(qū)塊鏈常用數(shù)據(jù)庫leveldb用java來實(shí)現(xiàn)常規(guī)操作的方法

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

LevelDB 是一種Key-Value存儲(chǔ)數(shù)據(jù)庫百度百科上介紹 性能非常強(qiáng)悍 可以支撐十億級(jí)這段時(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; }測(cè)試插入一百萬條數(shù)據(jù)

基于SpringBoot搭建的控制器

隨機(jī)生成 指定數(shù)量的UUID 并且插入到LevelDB

從請(qǐng)求 到響應(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); }

區(qū)塊鏈常用數(shù)據(jù)庫leveldb用java來實(shí)現(xiàn)常規(guī)操作的方法

測(cè)試從一百萬數(shù)據(jù)中取出一條

PostMan 請(qǐng)求到響應(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); }

區(qū)塊鏈常用數(shù)據(jù)庫leveldb用java來實(shí)現(xiàn)常規(guī)操作的方法

到此這篇關(guān)于區(qū)塊鏈常用數(shù)據(jù)庫leveldb用java來實(shí)現(xiàn)常規(guī)操作的文章就介紹到這了,更多相關(guān)區(qū)塊鏈常用數(shù)據(jù)庫leveldb用java來實(shí)現(xiàn)常規(guī)操作內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 福清市| 永德县| 万年县| 闽清县| 璧山县| 西和县| 五峰| 元谋县| 巨鹿县| 嘉峪关市| 尼勒克县| 江城| 乌什县| 东兴市| 论坛| 水城县| 安平县| 眉山市| 龙口市| 福泉市| 克什克腾旗| 体育| 屏山县| 巴青县| 保定市| 新河县| 无锡市| 开封市| 康定县| 皮山县| 会泽县| 贡觉县| 当雄县| 龙山县| 岳阳县| 高安市| 肃南| 阿坝县| 苏州市| 弋阳县| 关岭|