超级账本hyperledger fabric第六集:账本存储及源码阅读

账本存储概念:

  • peer节点做账本存储
  • orderer是临时存储区块,peer节点是账本存储的持久化,会改变世界状态

  • 文件系统,区块是存储为文件
  • 区块索引,用于查询区块,是用levleDB实现的
  • 状态数据库,一般存放区块链最新状态,数据不需要HA,可以从文件系统再次获取,couchDB支持模糊查询

交易读写集:

  • 回忆交易流程
    1. 交易模拟:在背书节点执行模拟时,最终返回交易读写集(RWset),告诉区块链在交易中读写了哪些数据
    2. 交易排序
    3. 交易验证,交易验证后,更新世界状态,更新的就是读写集中的写集
  • 交易读写集的3个概念
    1. 读集:包含键的列表,键的提交版本,读取对应的值,返回的是已提交的状态的值(读已提交),不能读取交易过程中写入的数据
    2. 写集:包含键的列表,写入的数据的值,如果多次写入,以最后一次为准
    3. 版本号:用区块高度和交易编号组成的
  • 交易验证阶段是对读写集进行验证(验证读集)
    1. 验证读集的版本号是否等于世界状态的版本号

账本存储相关概念:

  • 世界状态
    1. 交易执行后,所有键的最新值
  • 历史数据索引(可选)
  • 区块存储
    1. 按照文件去存  blocfile_xxxxxx
    2. 文件大小是64M,若修改,需要重新编译peer源码
    3. 账本最大容量64M*
  • 区块读取
    1. 区块文件流
    2. 区块流
    3. 迭代器
  • 区块索引
    1. 键:区块高度、区块哈希、交易哈希
    2. 值:区块文件编号、文件内的偏移量、区块数据的长度
  • 区块提交
    1. 保存到文件

账本存储相关源码:

  • 从4方面看,读写集、状态数据、历史数据、区块文件
  • 可以先从core/ledger下的ledger_interface.go中看大体结构


package ledger

import (
	commonledger "github.com/hyperledger/fabric/common/ledger"
	"github.com/hyperledger/fabric/protos/common"
	"github.com/hyperledger/fabric/protos/peer"
)

//类似于前面orderer节点的manager,控制中枢
type PeerLedgerProvider interface {
	//创建账本
	Create(genesisBlock *common.Block) (PeerLedger, error)
	//打开一个已有的账本
	Open(ledgerID string) (PeerLedger, error)
	//判断账本是否存在
	Exists(ledgerID string) (bool, error)
	//获取peer节点所有的账本
	List() ([]string, error)
	Close()
}

type PeerLedger interface {
	//账本文件存储
	commonledger.Ledger
	//Get获取一些账本的区块索引相关内容
	GetTransactionByID(txID string) (*peer.ProcessedTransaction, error)
	GetBlockByHash(blockHash []byte) (*common.Block, error)
	GetBlockByTxID(txID string) (*common.Block, error)
	//获取交易的状态
	//包含有效和无效
	//无效有很多种,可以点进TxValidationCode去看定义
	GetTxValidationCodeByTxID(txID string) (peer.TxValidationCode, error)
超级账本Hyperledger)是一个由Linux基金会主持的开源区块链项目,旨在建立一个可扩展的、可靠的区块链平台,以满足企业级应用程序的需求。其中,Hyperledger FabricHyperledger项目中最为成熟和广泛应用的一个区块链平台。 Hyperledger Fabric的特点: 1.灵活性:Hyperledger Fabric可以根据不同的业务需求进行配置,支持多种不同的共识算法和身份验证方式,可以根据实际情况进行设置。 2.私有性:Hyperledger Fabric支持私有部署,可以在企业内部搭建区块链网络,保障数据的私有性和安全性。 3.可扩展性:Hyperledger Fabric采用模块化架构,支持动态添加新的模块,可以根据需求进行扩展。 4.高效性:Hyperledger Fabric采用了分布式账本技术,可以实现高效的数据共享和传输,同时支持并发操作。 Hyperledger Fabric的架构: Hyperledger Fabric的架构可以分为四个主要部分:成员、通道、智能合约和账本。 1.成员:Hyperledger Fabric的成员可以是组织或个人,每个成员都有一个身份和相应的权限。成员可以通过身份验证和授权来访问网络中的资源。 2.通道:通道是Hyperledger Fabric中用于实现私有性的关键部分。通道可以将网络分成多个子网络,每个子网络中只有特定的成员可以访问,确保数据的私有性和安全性。 3.智能合约:智能合约是Hyperledger Fabric的核心部分,负责实现业务逻辑和数据交互。智能合约可以根据不同的业务需求进行编写,并在区块链上执行,确保数据的准确性和不可篡改性。 4.账本Hyperledger Fabric采用了分布式账本技术,将数据存储在多个节点上,确保数据的可靠性和安全性。每个节点都有一个完整的账本副本,可以进行数据的读写操作。 Hyperledger Fabric的应用场景: Hyperledger Fabric适用于各种不同的企业级应用场景,如供应链管理、金融服务、物流管理、保险等。其中,供应链管理是Hyperledger Fabric最为广泛应用的场景之一,通过区块链技术可以实现供应链上下游的数据共享和透明化,提高供应链管理的效率和准确性。 总结: Hyperledger Fabric是一个功能强大、灵活性高、可扩展性强的区块链平台,可以满足各种企业级应用场景的需求。未来,Hyperledger Fabric有望成为企业级区块链的标准平台之一,推动区块链技术在企业应用中的广泛推广和应用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值