整体结构
优质
小牛编辑
132浏览
2023-12-01
Hyperledger Fabric 在 1.0 中,架构已经解耦为三部分:
- fabric-https://yeasy.gitbooks.io/hyperledger_code_fabric/content/peer:主要起到 https://yeasy.gitbooks.io/hyperledger_code_fabric/content/peer 作用,包括 endorser、committer 两种角色;
- fabric-ca:即原先的 membersrvc,独立成一个新的项目。
- fabric-https://yeasy.gitbooks.io/hyperledger_code_fabric/content/order:起到 https://yeasy.gitbooks.io/hyperledger_code_fabric/content/order 作用。
其中,fabric-https://yeasy.gitbooks.io/hyperledger_code_fabric/content/peer 和 fabric-https://yeasy.gitbooks.io/hyperledger_code_fabric/content/order 代码暂时都在 fabric 项目中,未来可能进一步拆分。
核心代码
fabric 核心源代码目前约为 117K 行,主要包括代码、工具、脚本等部分。
$ find fabric -name "*.go" -not -path "fabric/https://yeasy.gitbooks.io/hyperledger_code_fabric/content/vendor/*" | xargs cat | wc -l116826
源代码
实现 fabric 功能的核心代码,包括:
- https://yeasy.gitbooks.io/hyperledger_code_fabric/content/accesscontrol 包:实现对 chaincode 的权限管理和属性校验等;
- https://yeasy.gitbooks.io/hyperledger_code_fabric/content/common 包:一些通用的模块;
- https://yeasy.gitbooks.io/hyperledger_code_fabric/content/core 包:大部分核心实现代码都在本包下。其它包的代码封装上层接口,最终调用本包内代码;
- https://yeasy.gitbooks.io/hyperledger_code_fabric/content/events 包:支持 event 框架;
- https://yeasy.gitbooks.io/hyperledger_code_fabric/content/examples 包:包括一些示例的 chaincode 代码;
- https://yeasy.gitbooks.io/hyperledger_code_fabric/content/flogging 包:封装 go-logging,提供日志支持;
- https://yeasy.gitbooks.io/hyperledger_code_fabric/content/gossip 包:实现 https://yeasy.gitbooks.io/hyperledger_code_fabric/content/gossip 协议;
- https://yeasy.gitbooks.io/hyperledger_code_fabric/content/metadata 包:版本信息等;
- https://yeasy.gitbooks.io/hyperledger_code_fabric/content/msp 包:Member Service Provider 包;
- https://yeasy.gitbooks.io/hyperledger_code_fabric/content/order 包:https://yeasy.gitbooks.io/hyperledger_code_fabric/content/order 服务相关的入口和框架代码;
- https://yeasy.gitbooks.io/hyperledger_code_fabric/content/peer 包:https://yeasy.gitbooks.io/hyperledger_code_fabric/content/peer 的入口和框架代码;
- https://yeasy.gitbooks.io/hyperledger_code_fabric/content/protos 包:包括各种协议和消息的 protobuf 定义文件;
源码相关工具
一些辅助代码包,包括:
- https://yeasy.gitbooks.io/hyperledger_code_fabric/content/bddtests:测试包,含有大量 bdd 测试用例;
- https://yeasy.gitbooks.io/hyperledger_code_fabric/content/gotools:golang 开发相关工具安装;
- https://yeasy.gitbooks.io/hyperledger_code_fabric/content/vendor 包:管理依赖;
安装部署
包括:
- https://yeasy.gitbooks.io/hyperledger_code_fabric/content/busybox:https://yeasy.gitbooks.io/hyperledger_code_fabric/content/busybox 环境,精简的 linux;
- https://yeasy.gitbooks.io/hyperledger_code_fabric/content/devenv:配置开发环境;
- https://yeasy.gitbooks.io/hyperledger_code_fabric/content/images:镜像生成模板等。
- https://yeasy.gitbooks.io/hyperledger_code_fabric/content/scripts:各种安装配置脚本;
其它工具
其他工具,包括:
配置、脚本和文档
除了些目录外,还包括一些说明文档、安装需求说明、License 信息文件等。
Docker 相关文件
- .baseimage-release:生成 baseimage 时候的版本号。
- .dockerignore:生成 Docker 镜像时忽略一些目录,包括 .git 目录。
git 相关文件
- .gitattributes:git 代码管理时候的属性文件,带有不同类型文件中换行符的规则,默认都为 linux 格式,即
\n
。 - .gitignore:git 代码管理时候忽略的文件和目录,包括 build 和 bin 等中间生成路径。
- .gitreview:使用 git review 时候的配置,带有项目的仓库地址信息。
- README.md:项目的说明文件,包括一些有用的链接等。
travis 相关文件
- .travis.yml:travis 配置文件,目前是使用 golang 1.6 编辑,运行了三种测试:unit-test、behave、node-sdk-unit-tests。
其它
- LICENSE:Apache 2 许可文件。
- docker-env.mk:被 Makefile 引用,生成 Docker 镜像时的环节变量。
- Makefile:执行测试、格式检查、安装依赖、生成镜像等操作。
- mkhttps://yeasy.gitbooks.io/hyperledger_code_fabric/content/docs.yml:生成 http://hyperledger-fabric.readthehttps://yeasy.gitbooks.io/hyperledger_code_fabric/content/docs.io 在线文档的配置文件。
- TravisCI_Readme.md