兄弟连区块链教程Fabric1.0源代码分析Peer peer根命令入口及加载子命令一
區塊鏈教程Fabric1.0源代碼分析Peer peer根命令入口及加載子命令,2018年下半年,區塊鏈行業正逐漸褪去發展之初的浮躁、回歸理性,表面上看相關人才需求與身價似乎正在回落。但事實上,正是初期泡沫的漸退,讓人們更多的關注點放在了區塊鏈真正的技術之上。
Fabric 1.0源代碼筆記 之 Peer #peer根命令入口及加載子命令
1、加載環境變量配置和配置文件
Fabric支持通過環境變量對部分配置進行更新,如:CORE_LOGGING_LEVEL為輸出的日志級別、CORE_PEER_ID為Peer的ID等。
此部分功能由第三方包viper來實現,viper除支持環境變量的配置方式外,還支持配置文件方式。
如下代碼為加載環境變量配置,其中cmdRoot為"core",即CORE_開頭的環境變量。
加載配置文件,同樣由第三方包viper來實現,具體代碼如下:
其中cmdRoot為"core",即/etc/hyperledger/fabric/core.yaml。
如下代碼為common.InitConfig(cmdRoot)的具體實現:
config.InitViper(nil, cmdRoot) err := viper.ReadInConfig() //代碼在peer/common/common.go另附config.InitViper(nil, cmdRoot)的代碼實現:
優先從環境變量FABRIC_CFG_PATH中獲取配置文件路徑,其次為當前目錄、開發環境目錄(即:src/github.com/hyperledger/fabric/sampleconfig)、和OfficialPath(即:/etc/hyperledger/fabric)。
AddDevConfigPath是對addConfigPath的封裝,目的是通過GetDevConfigDir()調取sampleconfig路徑。
2、加載命令行工具和命令
Fabric支持類似peer node start、peer channel create、peer chaincode install這種命令、子命令、命令選項的命令行形式。
此功能由第三方包cobra來實現,以peer chaincode install -n test_cc -v 1.0 -p github.com/hyperledger/fabric/examples/chaincode/go/chaincode_example02為例,
其中peer、chaincode、install、-n分別為命令、子命令、子命令的子命令、命令選項。
如下代碼為mainCmd的初始化,其中Use為命令名稱,PersistentPreRunE先于Run執行用于初始化日志系統,Run此處用于打印版本信息或幫助信息。
var mainCmd = &cobra.Command{Use: "peer",PersistentPreRunE: func(cmd *cobra.Command, args []string) error {loggingSpec := viper.GetString("logging_level")if loggingSpec == "" {loggingSpec = viper.GetString("logging.peer")}flogging.InitFromSpec(loggingSpec) //初始化flogging日志系統return nil},Run: func(cmd *cobra.Command, args []string) {if versionFlag {fmt.Print(version.GetInfo())} else {cmd.HelpFunc()(cmd, args)}}, } //代碼在peer/main.go如下代碼為添加命令行選項,-v, --version、--logging-level和--test.coverprofile分別用于版本信息、日志級別和測試覆蓋率分析。
mainFlags := mainCmd.PersistentFlags() mainFlags.BoolVarP(&versionFlag, "version", "v", false, "Display current version of fabric peer server") mainFlags.String("logging-level", "", "Default logging level and overrides, see core.yaml for full syntax") viper.BindPFlag("logging_level", mainFlags.Lookup("logging-level")) testCoverProfile := "" mainFlags.StringVarP(&testCoverProfile, "test.coverprofile", "", "coverage.cov", "Done") //代碼在peer/main.go如下代碼為逐一加載peer命令下子命令:node、channel、chaincode、clilogging、version。
mainCmd.AddCommand(version.Cmd()) mainCmd.AddCommand(node.Cmd()) mainCmd.AddCommand(chaincode.Cmd(nil)) mainCmd.AddCommand(clilogging.Cmd(nil)) mainCmd.AddCommand(channel.Cmd(nil)) //代碼在peer/main.gomainCmd.Execute()為命令啟動。
3、初始化日志系統(輸出對象、日志格式、日志級別)
如下為初始日志系統代碼入口,其中loggingSpec取自環境變量CORE_LOGGING_LEVEL或配置文件中logging.peer,即:全局的默認日志級別。
flogging.InitFromSpec(loggingSpec) //代碼在peer/main.go未完待續感謝關注兄弟連區塊鏈教程分享!
總結
以上是生活随笔為你收集整理的兄弟连区块链教程Fabric1.0源代码分析Peer peer根命令入口及加载子命令一的全部內容,希望文章能夠幫你解決所遇到的問題。