美文网首页
Java LevelDB 初体验

Java LevelDB 初体验

作者: Pencilso | 来源:发表于2018-06-27 11:43 被阅读286次

    前言

    LevelDB 是一种Key-Value存储数据库
    性能非常强悍 百度百科上介绍 可以支撑十亿级
    这段时间在研究区块链的时候发现的这个数据库
    

    引入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);
    }
    
    image

    测试从一百万数据中取出一条

    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);
    }   
    
    image

    相关文章

      网友评论

          本文标题:Java LevelDB 初体验

          本文链接:https://www.haomeiwen.com/subject/xzdbyftx.html