区块链常用数据库leveldb用java来实现常规操作的方法

2025-05-29 0 38

前言

LevelDB 是一种Key-Value存储数据库百度百科上介绍 性能非常强悍 可以支撑十亿级这段时间在研究区块链的时候发现的这个数据库。LevelDB 是单进程的服务,性能非常之高,在一台4核Q6600的CPU机器上,每秒钟写数据超过40w,而随机读的性能每秒钟超过10w。 此处随机读是完全命中内存的速度,如果是不命中 速度大大下降,LevelDB 只是一个 C/C++ 编程语言的库, 不包含网络服务封装, 所以无法像一般意义的存储服务器(如 MySQL)那样, 用客户端来连接它. LevelDB 自己也声明, 使用者应该封装自己的网络服务器.

引入SDK

?

1

2

3

4

5

6

7

8

9

10
<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

?

1

2

3

4

5
DBFactory factory = new Iq80DBFactory();

Options options = new Options();

options.createIfMissing(true);

//folder 是db存储目录

DB db = factory.open(new File(folder), options);

存储Key Value 值

?

1

2
//levelDB 的api存储都是字节数组 所以这里需要转成字节数组

db.put(Iq80DBFactory.bytes(key), Iq80DBFactory.bytes(value));

获取Value

?

1

2
byte[] bytes = db.get(Iq80DBFactory.bytes(key));

String value = Iq80DBFactory.asString(bytes);

删除|更改

?

1

2

3

4

5
//删除

db.delete(Iq80DBFactory.bytes(key));

//更改 重新put新的key - value即可

db.put(Iq80DBFactory.bytes(key), Iq80DBFactory.bytes(value));

遍历所有数据

?

1

2

3

4

5

6

7

8

9

10

11
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的时间 可能更快 哈哈

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14
@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毫秒

?

1

2

3

4

5

6

7
@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来实现常规操作内容请搜索快网idc以前的文章或继续浏览下面的相关文章希望大家以后多多支持快网idc!

原文链接:https://blog.csdn.net/ws327443752/article/details/113555246

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 区块链常用数据库leveldb用java来实现常规操作的方法 https://www.kuaiidc.com/108966.html

相关文章

发表评论
暂无评论