區塊鏈常用數據庫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);
    }

3404887b3eaa103ad6387e3.jpg

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

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

3404887000e3622dd0561ce.jpg

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章