在这篇文章中,使用fabric-samples/first-network中的文件进行fabric网络(solo类型的网络)搭建全过程的解析。如有错误欢迎批评指正。

至于Fabric网络的搭建这里不再介绍,可以参考这一篇文章Hyperledger Fabric环境搭建过程

fabric网络:单机,solo类型,两个组织,分别有两个节点

首先看一下该文件夹内有哪些文件:

  1. base connection-org2.json docker-compose-cli.yaml docker-compose-org3.yaml
  2. byfn.sh connection-org2.yaml docker-compose-couch-org3.yaml eyfn.sh
  3. channel-artifacts connection-org3.json docker-compose-couch.yaml org3-artifacts
  4. configtx.yaml connection-org3.yaml docker-compose-e2e-template.yaml README.md
  5. connection-org1.json crypto-config.yaml docker-compose-etcdraft2.yaml scripts
  6. connection-org1.yaml docker-compose-ca.yaml docker-compose-kafka.yaml

将本次用不到的文件删除,剩余的文件:

  1. .
  2. ├── base
  3.    ├── docker-compose-base.yaml
  4.    └── peer-base.yaml
  5. ├── channel-artifacts
  6. ├── configtx.yaml
  7. ├── crypto-config.yaml
  8. ├── docker-compose-cli.yaml
  9. ├── docker-compose-couch.yaml
  10. ├── docker-compose-e2e-template.yaml

1.证书的生成

在Fabric网络环境中,第一步需要生成各个节点的证书文件,所用到的配置文件为crypto-config.yaml,说明一下文件内各字段的意义:

  1. OrdererOrgs: #定义一个Order组织
  2. - Name: Orderer #order节点的名称,当前网络模式为solo类型,所以只定义了一个Order节点
  3. Domain: example.com #order节点的域
  4. Specs: #暂时用不到
  5. - Hostname: orderer
  6. - Hostname: orderer2
  7. - Hostname: orderer3
  8. - Hostname: orderer4
  9. - Hostname: orderer5
  10. PeerOrgs: #定义Peer组织
  11. - Name: Org1 #声明Peer组织名称为Org1
  12. Domain: org1.example.com #Org1组织的域
  13. EnableNodeOUs: true #节点组织单元,具体不了解,可以看crypto-config/peerOrganizations/*.example.com/msp/config.yaml文件了解
  14. Template: #在这里可以定义所生成的Org1组织中的Peer节点证书数量,不包括Admin
  15. Count: 2 #表明需要生成两个Peer节点的证书,如果需要其他数量的Peer节点,只需要更改这里的数量。
  16. Users: #在这里可以定义所生成的Org1组织中类型为User的证书数量,不包括Admin
  17. Count: 1 #生成用户的证书的数量
  18. - Name: Org2 #声明第二个Peer组织名称为Org2,如果需要更多的Peer组织证书,只需要按该模板添加即可。
  19. Domain: org2.example.com #与以上相同
  20. EnableNodeOUs: true
  21. Template:
  22. Count: 2
  23. Users:
  24. Count: 1

我们这里就使用两个组织,每个组织分别有两个节点和一个User。接下来我们使用该文件生成对应数量的证书:

  1. #路径需要更改为自己的路径
  2. cd ~/go/src/github.com/hyperledger/fabric/scripts/fabric-samples/first-network/
  3. #在这里可能会报错,通常是权限问题,可以添加sudo重新执行
  4. cryptogen generate --config=./crypto-config.yaml
  5. #执行完毕后,当前文件夹下会出现一个新的文件夹:crypto-config,在该文件夹下就是刚刚生成的证书.

文件夹内证书不再详解,会在另一篇文章中专门解释Fabric-ca的内容。

2 生成创世区块,通道配置,锚节点配置文件

在这里需要用到configtxgen这个二进制文件。

2.1生成创世区块

  1. #首先进入文件夹
  2. cd ~/go/src/github.com/hyperledger/fabric/scripts/fabric-samples/first-network/
  3. #执行命令生成创世区块
  4. configtxgen -profile TwoOrgsOrdererGenesis -channelID byfn-sys-channel -outputBlock ./channel-artifacts/genesis.block
  5. #如果没有channel-artifacts这个文件夹,则需要手动去创建

如果没有出现错误的话,在channel-artifacts文件夹中可以看至生成的genesis.block文件。

2.2生成通道配置信息

  1. #执行命令生成通道配置信息
  2. configtxgen -profile TwoOrgsChannel -outputCreateChannelTx ./channel-artifacts/channel.tx -channelID mychannel

同样,在channel-artifacts文件夹中可以看至生成的channel.tx文件。

2.3生成锚节点配置文件

  1. #首先生成Org1的锚节点配置文件
  2. configtxgen -profile TwoOrgsChannel -outputAnchorPeersUpdate ./channel-artifacts/Org1MSPanchors.tx -channelID mychannel -asOrg Org1MSP
  3. #生成Org2的锚节点配置文件
  4. configtxgen -profile TwoOrgsChannel -outputAnchorPeersUpdate ./channel-artifacts/Org2MSPanchors.tx -channelID mychannel -asOrg Org2MSP

所有需要的配置文件全部建立完成,在channel-artifacts中应该有以下几个文件:

  1. channel.tx genesis.block Org1MSPanchors.tx Org2MSPanchors.tx

3启动网络

到了这一步,可以启动网络了。

  1. #首先进入``fabric-samples/first-network``文件夹。
  2. cd ~/go/src/github.com/hyperledger/fabric/scripts/fabric-samples/first-network/
  3. #启动容器
  4. sudo docker-compose -f docker-compose-cli.yaml up -d

执行以下命令查看容器是否启动成功:

  1. sudo docker ps
  2. #如果可以看到如下信息说明启动成功
  3. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  4. 17d79586b1b7 hyperledger/fabric-tools:latest "/bin/bash" 30 seconds ago Up 28 seconds cli
  5. 0f4adb6b578e hyperledger/fabric-orderer:latest "orderer" 57 seconds ago Up 29 seconds 0.0.0.0:7050->7050/tcp orderer.example.com
  6. e2795ea9d43b hyperledger/fabric-peer:latest "peer node start" 57 seconds ago Up 30 seconds 0.0.0.0:10051->10051/tcp peer1.org2.example.com
  7. 247a6e4fdd62 hyperledger/fabric-peer:latest "peer node start" 57 seconds ago Up 30 seconds 0.0.0.0:9051->9051/tcp peer0.org2.example.com
  8. ad4af3309e8c hyperledger/fabric-peer:latest "peer node start" 57 seconds ago Up 31 seconds 0.0.0.0:8051->8051/tcp peer1.org1.example.com
  9. f6d25896b517 hyperledger/fabric-peer:latest "peer node start" 58 seconds ago Up 40 seconds 0.0.0.0:7051->7051/tcp peer0.org1.example.com

3.1创建通道

创建通道需要进入cli容器:

  1. sudo docker exec -it cli bash
  2. #看到光标前的信息变为
  3. root@17d79586b1b7:/opt/gopath/src/github.com/hyperledger/fabric/peer#
  4. #则成功进入容器

首先配置环境变量:

  1. #当前cli容器默认配置是节点peer0,所以不需要其他配置信息
  2. ORDERER_CA=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem
  3. #创建通道信息
  4. peer channel create -o orderer.example.com:7050 -c mychannel -f ./channel-artifacts/channel.tx --tls true --cafile $ORDERER_CA
  5. #看到如下信息说明创建通道成功
  6. 2019-06-20 13:05:55.829 UTC [channelCmd] InitCmdFactory -> INFO 001 Endorser and orderer connections initialized
  7. 2019-06-20 13:05:55.926 UTC [cli.common] readBlock -> INFO 002 Received block: 0
  8. #将生成的文件移动到channel-artifacts文件夹中
  9. mv mychannel.block channel-artifacts/

3.2加入通道

  1. #因为当前cli容器使用的是peer0的配置,所以可以直接将peer0加入通道
  2. peer channel join -b channel-artifacts/mychannel.block
  3. #更新环境变量使其他节点也加入通道
  4. #=========peer1.org1=========== 注意这里端口要与上面文件中配置的端口号相同
  5. CORE_PEER_ADDRESS=peer1.org1.example.com:8051
  6. #=========peer0.org2============
  7. CORE_PEER_LOCALMSPID="Org2MSP"
  8. CORE_PEER_TLS_ROOTCERT_FILE=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org2.example.com/peers/peer0.org2.example.com/tls/ca.crt
  9. CORE_PEER_MSPCONFIGPATH=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org2.example.com/users/Admin@org2.example.com/msp
  10. CORE_PEER_ADDRESS=peer0.org2.example.com:9051
  11. peer channel join -b channel-artifacts/mychannel.block
  12. #=========peer1.org2=============
  13. CORE_PEER_ADDRESS=peer1.org2.example.com:10051
  14. peer channel join -b channel-artifacts/mychannel.block
  15. #退出容器
  16. exit

3.3更新锚节点

  1. #重新进入容器
  2. sudo docker exec -it cli bash
  3. #更新环境变量
  4. ORDERER_CA=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem
  5. #========Org1================
  6. peer channel update -o orderer.example.com:7050 -c mychannel -f ./channel-artifacts/Org1MSPanchors.tx --tls true --cafile $ORDERER_CA
  7. #========Org2================
  8. #更新环境变量
  9. CORE_PEER_LOCALMSPID="Org2MSP"
  10. CORE_PEER_TLS_ROOTCERT_FILE=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org2.example.com/peers/peer0.org2.example.com/tls/ca.crt
  11. CORE_PEER_MSPCONFIGPATH=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org2.example.com/users/Admin@org2.example.com/msp
  12. CORE_PEER_ADDRESS=peer0.org2.example.com:9051
  13. peer channel update -o orderer.example.com:7050 -c mychannel -f ./channel-artifacts/Org2MSPanchors.tx --tls true --cafile $ORDERER_CA
  14. #退出容器
  15. exit

3.4安装链码

  1. #链码的安装仍然需要在所有节点上进行操作
  2. #进入容器
  3. sudo docker exec -it cli bash
  4. #更新环境变量
  5. ORDERER_CA=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem
  6. #=========peer0.org1===========
  7. #这里很有可能会出现路径不存在的错误,解决方法是在容器内找到对应的链码所在位置,然后替换当前链码路径
  8. ##比如本文中链码路径为/opt/gopath/src/github.com/chaincode/chaincode_example02/go
  9. ##则可以将以下命令的链码路径更改为github.com/chaincode/chaincode_example02
  10. peer chaincode install -n mycc -v 1.0 -p github.com/hyperledger/fabric/examples/chaincode/go/chaincode_example02
  11. #实例化链码 该步骤创建了a,b两个账户,其中a账户余额定义为100,b账户余额定义为200
  12. peer chaincode instantiate -o orderer.example.com:7050 --tls true --cafile $ORDERER_CA -C mychannel -n mycc -v 1.0 -c '{"Args":["init","a","100","b","200"]}' -P "OR ('Org1MSP.member','Org2MSP.member')"
  13. #这一步执行完毕后可以在其他节点上也安装链码,具体环境变量配置见本文中4.2

3.5调用链码

  1. #以peer0.org1为例
  2. #首先进入cli容器
  3. sudo docker exec -it cli bash
  4. #执行以下命令进行查询a账户余额
  5. peer chaincode query -C mychannel -n mycc -c '{"Args":["query","a"]}'
  6. #如果命令行输出100说明链码成功调用.
  7. #接下来我们发起一笔交易:通过peer0.org1节点将a账户余额转账给b20
  8. peer chaincode invoke -o orderer.example.com:7050 --tls true --cafile $ORDERER_CA -C mychannel -n mycc -c '{"Args":["invoke","a","b","10"]}'
  9. #然后登陆peer1.org1节点进行查询
  10. CORE_PEER_ADDRESS=peer1.org1.example.com:8051
  11. peer chaincode query -C mychannel -n mycc -c '{"Args":["query","a"]}'
  12. #如果输出结果为:80
  13. 说明Fabric网络手动搭建成功
  14. #退出容器
  15. exit

最后关闭网络:

  1. sudo docker-compose -f docker-compose-cli.yaml down --volumes
  2. #删除生成的文件,下次启动网络需要重新生成
  3. sudo rm -r channel-artifacts crypto-config

4总结

本文并没有使用CouchDb作为fabric网络的数据库,准备放到下一篇多机搭建Fabric网络中一起讲解。到这里,整个网络的手动搭建过程已经完成,希望大家能够有所收获。

深入解析Hyperledger Fabric启动的全过程的更多相关文章

  1. 死磕hyperledger fabric源码|Order节点概述

    死磕hyperledger fabric源码|Order节点概述 文章及代码:https://github.com/blockchainGuide/ 分支:v1.1.0 前言及源码目录 Orderer ...

  2. Hyperledger Fabric源码解析

    Hyperledger Fabric开源于2015年12月,截至2018年2月初有185个公司/组织成员加入.最初由IBM和DAH的工程师贡献,现在约有70名的代码贡献者,4000+代码提交,代码行数 ...

  3. Hyperledger Fabric相关文件解析

    1相关文件说明 这一部分涉及相关配置文件的解析, 网络的启动涉及到多个文件,本文按以下顺序进行分析: . ├── base │   ├── docker-compose-base.yaml #1 │  ...

  4. Hyperledger Fabric 1.0 从零开始(七)——启动Fabric多节点集群

    5:启动Fabric多节点集群 5.1.启动orderer节点服务 上述操作完成后,此时各节点的compose配置文件及证书验证目录都已经准备完成,可以开始尝试启动多机Fabric集群. 首先启动or ...

  5. Hyperledger Fabric 1.0 从零开始(九)——Fabric多节点集群生产启动

    7:Fabric多节点集群生产启动 7.1.多节点服务器配置 在生产环境上,我们沿用4.1.配置说明中的服务器各节点配置方案. 我们申请了五台生产服务器,其中四台服务器运行peer节点,另外一台服务器 ...

  6. HyperLedger Fabric基于zookeeper和kafka集群配置解析

    简述 在搭建HyperLedger Fabric环境的过程中,我们会用到一个configtx.yaml文件(可参考Hyperledger Fabric 1.0 从零开始(八)--Fabric多节点集群 ...

  7. Hyperledger Fabric 账本结构解析

    前言 现在很多人都在从事区块链方面的研究,作者也一直在基于Hyperledger Fabric做一些开发工作.为了方便后来人更快的入门,本着“开源”的精神,在本文中向大家讲解一下Hyperledger ...

  8. 搭建基于hyperledger fabric的联盟社区(五) --启动Fabric网络

    现在所有的文件都已经准备完毕,我们可以启动fabric网络了. 一.启动orderer节点 在orderer服务器上运行: cd ~/go/src/github.com/hyperledger/fab ...

  9. Hyperledger Fabric 1.0 学习搭建 (五)--- 启动Fabric多节点集群

    5.1.启动orderer节点服务 上述操作完成后,此时各节点的compose配置文件及证书验证目录都已经准备完成,可以开始尝试启动多机Fabric集群. 首先启动orderer节点,切换至order ...

随机推荐

  1. 为 Mac Finder 增加右键文件打包压缩(免费)

    在 Windows 上用惯了 7-Zip 和 WinRAR,来到 Mac 却突然发现没有类似的工具?Mac 自带的 Zip 工具确实让人吐糟无力,压缩率低就不说了,因为 Mac 上文件名是 Unico ...

  2. jvm常用优化方案和方法

    新生代 GC(Minor GC):指发生在新生代的垃圾收集动作,因为 Java 对象大多都具备朝生夕灭的特性,所以 Minor GC 非常频繁,一般回收速度也比较快. 老年代 GC(Major GC ...

  3. JDK源代码学习系列03----StringBuffer+StringBuilder

                         JDK源代码学习系列03----StringBuffer+StringBuilder 因为前面学习了StringBuffer和StringBuilder的父类 ...

  4. Python Tricks(二十二)—— small tricks

    多次 import import numpy as np, matplotlib.pyplot as plt ndarray 的强制类型转换 v = v.astype(np.int) python 的 ...

  5. 对于ado.net dataProvider的介绍

    学习刘皓的 ADO.NET入门教程(二)了解.NET数据提供程序 而来 这篇文章很一般,主要是对dataProvider做了个简单的介绍.因为在该系列文章中提到,ado.net主要有两部分 dataP ...

  6. OpenCV实现马赛克和毛玻璃滤镜效果

    一.马赛克效果 马赛克的实现原理是把图像上某个像素点一定范围邻域内的所有点用邻域内随机选取的一个像素点的颜色代替,这样可以模糊细节,但是可以保留大体的轮廓. 以下OpenCV程序实现马赛克效果,通过鼠 ...

  7. python中的验证码识别库PyTesser

    PyTesser PyTesser is an Optical Character Recognition module for Python. It takes as input an image ...

  8. Centos上通过shell脚本实现数据库备份和还原

    最近有个这样的需求,通过shell脚本实现数据库备份还原,最后通过网上查询自己测试实现,将脚本分享给大家 1.数据库备份脚本 #!/bin/bash ds=`` list=`date +%Y`/`da ...

  9. JS enter代替tab,只有部分键可以代替

    <!DOCTYPE html><html><head><meta http-equiv="Content-Type" content=&q ...

  10. windows下捕获dump之Google breakpad_client

    breakpad是Google开源的一套跨平台工具,用于dump的处理.很全的一套东西,我这里只简单涉及breakpad客户端,不涉及纯文本符号生成,不涉及dump解析. 一.使用 最简单的是使用进程 ...