欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

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

时间:2021-04-04 10:15:18|栏目: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

上一篇:Java中获取时间戳的三种方式对比实现

栏    目:JAVA代码

下一篇:SpringBoot2 JPA解决懒加载异常的问题

本文标题:区块链常用数据库leveldb用java来实现常规操作的方法

本文地址:http://www.codeinn.net/misctech/94343.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有