前言
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);
}
|
测试从一百万数据中取出一条
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来实现常规操作内容请搜索快网idc以前的文章或继续浏览下面的相关文章希望大家以后多多支持快网idc!
原文链接:https://blog.csdn.net/ws327443752/article/details/113555246
相关文章
- ASP.NET本地开发时常见的配置错误及解决方法? 2025-06-10
- ASP.NET自助建站系统的数据库备份与恢复操作指南 2025-06-10
- 个人网站服务器域名解析设置指南:从购买到绑定全流程 2025-06-10
- 个人网站搭建:如何挑选具有弹性扩展能力的服务器? 2025-06-10
- 个人服务器网站搭建:如何选择适合自己的建站程序或框架? 2025-06-10
- 2025-07-10 怎样使用阿里云的安全工具进行服务器漏洞扫描和修复?
- 2025-07-10 怎样使用命令行工具优化Linux云服务器的Ping性能?
- 2025-07-10 怎样使用Xshell连接华为云服务器,实现高效远程管理?
- 2025-07-10 怎样利用云服务器D盘搭建稳定、高效的网站托管环境?
- 2025-07-10 怎样使用阿里云的安全组功能来增强服务器防火墙的安全性?
快网idc优惠网
QQ交流群
-
2025-06-04 106
-
2025-05-25 99
-
如何使用php脚本给html中引用的js和css路径打上版本号
2025-05-29 84 -
ThinkPHP框架整合微信支付之Native 扫码支付模式一图文详解
2025-05-27 46 -
2025-05-27 31



