以太坊的存储层技术分析之一:存储层及LevelDB

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 :=

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值