在Fabric中,Peer(节点)是指在网络中负责接收交易请求、维护一致账本的各个fabric-peer实例。节点之间彼此通过gRPC通信。
按角色划分,Peer包括两种类型:
Peer核心代码在peer目录下,其他相关代码分布在core/peer和protos/peer目录下。目录结构如下:
core/endorser目录:背书服务端。
????
如下为分节说明Peer代码:
//为全局变量localAddress和peerEndpoint赋值
func CacheConfiguration() (err error)
func cacheConfiguration() //调用CacheConfiguration()
//获取localAddress
func GetLocalAddress() (string, error)
//获取peerEndpoint
func GetPeerEndpoint() (*pb.PeerEndpoint, error)
//获取Peer安全配置
func GetSecureConfig() (comm.SecureServerConfig, error)
//代码在core/peer/config.go
PeerEndpoint结构体定义如下:
type PeerID struct {
????Name string
}
type PeerEndpoint struct {
????Id *PeerID
????Address string
}
//代码在protos/peer/peer.pb.go
SecureServerConfig结构体定义如下:
type SecureServerConfig struct {
????ServerCertificate []byte //签名公钥,取自peer.tls.cert.file
????ServerKey []byte //签名私钥,取自peer.tls.key.file
????ServerRootCAs [][]byte //根CA证书,取自peer.tls.rootcert.file
????ClientRootCAs [][]byte
????UseTLS bool //是否启用TLS,取自peer.tls.enabled
????RequireClientCert bool
}
//代码在core/comm/server.go
func (cs *chainSupport) Ledger() ledger.PeerLedger
func (cs *chainSupport) GetMSPIDs(cid string) []string
func MockInitialize()
func MockSetMSPIDGetter(mspIDGetter func(string) []string)
func Initialize(init func(string)) //Peer初始化,并部署系统链码
func InitChain(cid string)
func getCurrConfigBlockFromLedger(ledger ledger.PeerLedger) (*common.Block, error)
func createChain(cid string, ledger ledger.PeerLedger, cb *common.Block) error
func CreateChainFromBlock(cb *common.Block) error
func MockCreateChain(cid string) error
func GetLedger(cid string) ledger.PeerLedger
func GetPolicyManager(cid string) policies.Manager
func GetCurrConfigBlock(cid string) *common.Block
func updateTrustedRoots(cm configtxapi.Manager)
func buildTrustedRootsForChain(cm configtxapi.Manager)
func GetMSPIDs(cid string) []string
func SetCurrConfigBlock(block *common.Block, cid string) error
func NewPeerClientConnection() (*grpc.ClientConn, error)
func GetLocalIP() string
func NewPeerClientConnectionWithAddress(peerAddress string) (*grpc.ClientConn, error)
func GetChannelsInfo() []*pb.ChannelInfo
//构造type channelPolicyManagerGetter struct{}
func NewChannelPolicyManagerGetter() policies.ChannelPolicyManagerGetter
func (c *channelPolicyManagerGetter) Manager(channelID string) (policies.Manager, bool)
func CreatePeerServer(listenAddress string,secureConfig comm.SecureServerConfig) (comm.GRPCServer, error)
func GetPeerServer() comm.GRPCServer
//代码在core/peer/peer.go
原文:http://blog.51cto.com/14041296/2313018