Fabric 1.0源代码分析(23)LevelDB(KV数据库)

栏目: 数据库 · 发布时间: 6年前

内容简介:LevelDB是Google开源的持久化KV单机数据库,具有很高的随机写,顺序读/写性能,但是随机读的性能很一般,也就是说,LevelDB很适合应用在查询较少,而写很多的场景。

# Fabric 1.0源代码笔记 之 LevelDB(KV数据库)

## 1、LevelDB概述

LevelDB是Google开源的持久化KV单机数据库,具有很高的随机写,顺序读/写性能,但是随机读的性能很一般,也就是说,LevelDB很适合应用在查询较少,而写很多的场景。

LevelDB的特点:

* key和value都是任意长度的字节数组;

* entry(即一条K-V记录)默认是按照key的字典顺序存储的,当然开发者也可以重载这个 排序 函数;

* 提供的基本操作接口:Put()、Delete()、Get()、Batch();

* 支持批量操作以原子操作进行;

* 可以创建数据全景的snapshot(快照),并允许在快照中查找数据;

* 可以通过前向(或后向)迭代器遍历数据(迭代器会隐含的创建一个snapshot);

* 自动使用Snappy压缩数据;

* 可移植性;

Fabric中使用了goleveldb包,即https://github.com/syndtr/goleveldb/。

goleveldb的基本操作:

* 打开数据库,db, err:=leveldb.OpenFile("./db", nil)。作用就是在当前目录下创建一个db文件夹作为数据库的目录。

* 存储键值,db.Put([]byte("key1"),[]byte("value1"),nil)。作用就是在数据库中存储键值对 key1-value1。leveldb数据库中对键值的操作都是byte格式化的数据。

* 获取键值对,data,_ := db.Get([]byte("key1"),nil),获取key1对应的值。

* 遍历数据库,iter := db.NewIterator(nil, nil),for iter.Next(){ fmt.Printf("key=%s,value=%s\n",iter.Key(),iter.Value()) },iter.Release()。作用就是建立迭代器iter,然后依次遍历数据库中所有的数据并打印键和值,最后释放迭代器iter。

* 关闭数据库,db.Close()。

Fabric中LevelDB代码,分布在common/ledger/util/leveldbhelper目录,目录结构如下:

* leveldb_provider.go,定义了结构体Provider、Provider、UpdateBatch、Iterator及其方法。

* leveldb_helper.go,定义了DB结构体及方法。

## 2、DB结构体及方法

DB结构体定义:对实际数据存储的包装。

```go

type Conf struct {

DBPath string //路径

}

type DB struct {

conf *Conf //配置

db *leveldb.DB //leveldb.DB对象

dbState dbState //type dbState int32

mux sync.Mutex //锁

readOpts *opt.ReadOptions

writeOptsNoSync *opt.WriteOptions

writeOptsSync *opt.WriteOptions

}

//代码在common/ledger/util/leveldbhelper/leveldb_helper.go

```

涉及如下方法:对goleveldb包做了封装。

```go

func CreateDB(conf *Conf) *DB //创建DB实例

func (dbInst *DB) Open() //leveldb.OpenFile,创建并打开leveldb数据库(如目录不存在则创建)

func (dbInst *DB) Close() //db.Close()

func (dbInst *DB) Get(key [] byte ) ([] byte , error ) //db.Get

func (dbInst *DB) Put(key [] byte , value [] byte , sync bool ) error //db.Put

func (dbInst *DB) Delete(key [] byte , sync bool ) error //db.Delete

func (dbInst *DB) GetIterator(startKey [] byte , endKey [] byte ) iterator.Iterator //db.NewIterator,创建迭代器

func (dbInst *DB) WriteBatch(batch *leveldb.Batch, sync bool ) error //db.Write,批量写入

//代码在common/ledger/util/leveldbhelper/leveldb_helper.go

```

## 3、DBHandle结构体及方法

DBHandle结构体定义:封装DB,目的为给key添加dbName前缀,添加和拆除前缀通过constructLevelKey(h.dbName, key)和retrieveAppKey()实现。

```go

type DBHandle struct {

dbName string //DB名称

db *DB //type DB struct

}

//代码在common/ledger/util/leveldbhelper/leveldb_provider.go

```

涉及如下方法:

```go

func (h *DBHandle) Get(key [] byte ) ([] byte , error ) //h.db.Get

func (h *DBHandle) Put(key [] byte , value [] byte , sync bool ) error //h.db.Put

func (h *DBHandle) Delete(key [] byte , sync bool ) error //h.db.Delete

func (h *DBHandle) WriteBatch(batch *UpdateBatch, sync bool ) error //h.db.WriteBatch

func (h *DBHandle) GetIterator(startKey [] byte , endKey [] byte ) *Iterator //h.db.GetIterator

//代码在common/ledger/util/leveldbhelper/leveldb_provider.go

```

补充UpdateBatch结构体及方法:

```go

type UpdateBatch struct {

KVs map [ string ][] byte

}

func NewUpdateBatch() *UpdateBatch //构造UpdateBatch

func (batch *UpdateBatch) Put(key [] byte , value [] byte ) //batch.KVs[string(key)] = value

func (batch *UpdateBatch) Delete(key [] byte ) //batch.KVs[string(key)] = nil

//代码在common/ledger/util/leveldbhelper/leveldb_provider.go

```

补充Iterator结构体及方法:封装github.com/syndtr/goleveldb/leveldb/iterator。

```go

type Iterator struct {

iterator.Iterator

}

func (itr *Iterator) Key() [] byte //itr.Iterator.Key()拆除dbName

func constructLevelKey(dbName string , key [] byte ) [] byte //为key添加dbName

func retrieveAppKey(levelKey [] byte ) [] byte //为key拆除dbName

//代码在common/ledger/util/leveldbhelper/leveldb_provider.go

```

## 4、Provider结构体及方法

Provider结构体定义:将单个物理LevelDB,虚拟为多个逻辑LevelDB

```go

type Provider struct {

db *DB

dbHandles map [ string ]*DBHandle

mux sync.Mutex

}

//代码在common/ledger/util/leveldbhelper/leveldb_provider.go

```

涉及方法如下:

```go

func NewProvider(conf *Conf) *Provider { //创建并打开db,构造Provider

db := CreateDB(conf)

db.Open()

return &Provider{db, make ( map [ string ]*DBHandle), sync.Mutex{}}

}

//获取名称为dbName的leveldb句柄

func (p *Provider) GetDBHandle(dbName string ) *DBHandle {

p.mux.Lock()

defer p.mux.Unlock()

dbHandle := p.dbHandles[dbName]

if dbHandle == nil {

dbHandle = &DBHandle{dbName, p.db}

p.dbHandles[dbName] = dbHandle

}

return dbHandle

}

//关闭leveldb

func (p *Provider) Close() {

p.db.Close()

}

//代码在common/ledger/util/leveldbhelper/leveldb_provider.go

```

Fabric 1.0源代码分析(23)LevelDB(KV数据库) Fabric 1.0源代码分析(23)LevelDB(KV数据库)

网址:http://www.qukuailianxueyuan.io/

Fabric 1.0源代码分析(23)LevelDB(KV数据库)

Fabric 1.0源代码分析(23)LevelDB(KV数据库)

欲领取造币技术与全套虚拟机资料

区块链技术交流QQ群: 756146052   备注:CSDN

尹成学院微信:备注:CSDN

Fabric 1.0源代码分析(23)LevelDB(KV数据库)

Fabric 1.0源代码分析(23)LevelDB(KV数据库) Fabric 1.0源代码分析(23)LevelDB(KV数据库)

网址:http://www.qukuailianxueyuan.io/

Fabric 1.0源代码分析(23)LevelDB(KV数据库)

Fabric 1.0源代码分析(23)LevelDB(KV数据库)

欲领取造币技术与全套虚拟机资料

区块链技术交流QQ群: 756146052   备注:CSDN

尹成学院微信:备注:CSDN

Fabric 1.0源代码分析(23)LevelDB(KV数据库)


以上所述就是小编给大家介绍的《Fabric 1.0源代码分析(23)LevelDB(KV数据库)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

数据结构

数据结构

严蔚敏、吴伟民 / 清华大学出版社 / 2007-3-1 / 30.0

《数据结构》(C语言版)是为“数据结构”课程编写的教材,也可作为学习数据结构及其算法的C程序设计的参数教材。 本书的前半部分从抽象数据类型的角度讨论各种基本类型的数据结构及其应用;后半部分主要讨论查找和排序的各种实现方法及其综合分析比较。其内容和章节编排1992年4月出版的《数据结构》(第二版)基本一致,但在本书中更突出了抽象数据类型的概念。全书采用类C语言作为数据结构和算法的描述语言。 ......一起来看看 《数据结构》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具