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

 更新时间:2021年02月03日 09:36:36   作者:向彪-blockchain  
这篇文章主要介绍了区块链常用数据库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

到此这篇关于区块链常用数据库leveldb用java来实现常规操作的文章就介绍到这了,更多相关区块链常用数据库leveldb用java来实现常规操作内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 一文搞懂并学会使用SpringBoot的Actuator运行状态监控组件的详细教程

    一文搞懂并学会使用SpringBoot的Actuator运行状态监控组件的详细教程

    这篇文章主要介绍了一文搞懂并学会使用SpringBoot的Actuator运行状态监控组件,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • SpringBoot实现的Mongodb管理工具使用解析

    SpringBoot实现的Mongodb管理工具使用解析

    这篇文章主要介绍了SpringBoot实现的Mongodb管理工具使用解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-09-09
  • Java使用lambda表达式简化代码的示例详解

    Java使用lambda表达式简化代码的示例详解

    这篇文章主要给大家介绍了Java如何使用lambda表达式简化代码的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-11-11
  • Java多线程并发的指令重排序问题及volatile写屏障原理详解

    Java多线程并发的指令重排序问题及volatile写屏障原理详解

    这篇文章主要介绍了Java多线程并发的指令重排序问题及volatile写屏障原理详解,指令重排序是编译器或处理器为了提高性能而对指令执行顺序进行重新排列的优化技术,需要的朋友可以参考下
    2024-01-01
  • java8版本base64加密解密的实例

    java8版本base64加密解密的实例

    下面小编就为大家分享一篇java8版本base64加密解密的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2017-12-12
  • Spring Boot 日志配置方法(超详细)

    Spring Boot 日志配置方法(超详细)

    默认情况下,Spring Boot会用Logback来记录日志,并用INFO级别输出到控制台。下面通过本文给大家介绍Spring Boot 日志配置方法详解,感兴趣的朋友参考下吧
    2017-07-07
  • Java组件FileUpload上传文件实现代码

    Java组件FileUpload上传文件实现代码

    这篇文章主要为大家详细介绍了Java组件FileUpload上传文件实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-06-06
  • SpringBoot 如何使用Dataway配置数据查询接口

    SpringBoot 如何使用Dataway配置数据查询接口

    这篇文章主要介绍了SpringBoot 如何使用Dataway配置数据查询接口,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-11-11
  • Java实现五子棋的基础方法

    Java实现五子棋的基础方法

    这篇文章主要为大家详细介绍了Java实现五子棋的基础方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-09-09
  • 如何在 Java 中实现不可变类

    如何在 Java 中实现不可变类

    这篇文章主要介绍了如何在 Java 中实现不可变类,不变性是函数式编程的关键,因为它与尽量减少变化部分的这一目标相一致,这使得对这些部分的推断更为容易一些。,需要的朋友可以参考下
    2019-06-06

最新评论