评论

收藏

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

编程语言 编程语言 发布于:2021-08-17 11:37 | 阅读数:388 | 评论:0

前言
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);
  }
DSC0000.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);
  }
DSC0001.jpg

到此这篇关于区块链常用数据库leveldb用java来实现常规操作的文章就介绍到这了,更多相关区块链常用数据库leveldb用java来实现常规操作内容请搜索CodeAE代码之家
以前的文章或继续浏览下面的相关文章希望大家以后多多支持CodeAE代码之家!
原文链接:https://blog.csdn.net/ws327443752/article/details/113555246

关注下面的标签,发现更多相似文章