前言
LevelDB 是一种Key-Value存储数据库百度百科上介绍 性能非常强悍 可以支撑十亿级这段时间在研究区块链的时候发现的这个数据库。LevelDB 是单进程的服务,性能非常之高,在一台4核Q6600的CPU机器上,每秒钟写数据超过40w,而随机读的性能每秒钟超过10w。 此处随机读是完全命中内存的速度,如果是不命中 速度大大下降,LevelDB 只是一个 C/C++ 编程语言的库, 不包含网络服务封装, 所以无法像一般意义的存储服务器(如 MySQL)那样, 用客户端来连接它. LevelDB 自己也声明, 使用者应该封装自己的网络服务器.
引入SDK
org.iq80.leveldb
leveldb-api
0.10
org.iq80.leveldb
leveldb
0.10
初始化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 = Iq80