LevelDB数据库技术是以太坊所采用的存储层技术。从架构设计上来说,区块链可以简单的分为三个层次,从上到下分别是应用层、扩展层和协议层。其中,协议层又可以分为网络层和存储层,它们相互独立但又不可分割(图1)。
存储层是区块链技术中重要的技术环节,也是最底层的技术环节。区块链节点启动时,需要从保存在磁盘上的数据库中读取以往区块,为区块同步做准备;区块链应用各节点达成共识后,要写入数据库,方能将共识固化下来;存储层的性能容量对区块链整体性能容量有重大影响。
LevelDB本身是集成到以太坊的,为了更好地研究,有必要单独拿出LevelDB进行体验,掌握其整体架构,为研究其和以太坊的对接做准备。
安装命令:
go get github.com/syndtr/goleveldb/leveldb
调用代码实例:
// The returned DB instance is safe for concurrent use. Which mean that all
// DB's methods may be called concurrently from multiple goroutine.
db, err := leveldb.OpenFile("path/to/db", nil) //打开数据库并获得链接
...
defer db.Close()
{ //如下是打开数据库后的使用,主要就3个,put,get,delete
db.Put([]byte("key"), []byte("value"), nil)
data, err :=