以下内容皆为个人理解,并未参照任何文章数据,如有理解错误,欢迎指正。
程序入口:peer/main.go
在main.go中主要有四句重要代码,
peer/version : peer 版本。
node : 涉及本地节点的搭建,以及如何加入到网络,本机IP地址端口号,是VP节点还是NVP节点等。
network : 远程登录devops服务器,查询所有peer节点。
chaincode : chaincode三种操作deploy invoke query (通过命令行发送给devops服务器)
接着调用 mainCmd.Execute() 执行命令分发。
比较重要的模块是node,其中start命令负责该节点的初始化流程。
一、node/start
调用serve()函数
1. 调用 CacheConfiguration() 函数设置缓存数据,缓存数据包括该peer的LocalAdress、PeerEndpoint(是VP or NVP)等等
2. 设置服务器地址,创建服务器实例,后续代码会使用lis。
3.创建 createEventHubServer 该函数创建事件Hub服务器(创建线程运行),同时为该服务器创建监听实例,调用
RegisterEventsServer 函数将EventHubServer注册到grpcService上。该函数有一部分关于TLS的调用,这里分析先不考虑HTTPS的情况,这并不影响我们分析fabric。
4.db.Start() start database 数据库处理模块需单独分析。
5. getSecHelper() 这里不分析安全模块
6. 调用 registerChaincodeSupport() 该函数主要作用是将系统chaincode部署到docker上,同时根据第一个参数chainname创建ChainCodeSupport 实例,
该实例包括 chaincode路径、超时时间、chainname等数据信息。将得到的ChainCodeSupport实例注册到grpcServer。