Fabric 2.0区块链开发环境安装
本文介绍如何安装最新的Hyperledger Fabric 2.0的预编译程序、fabric-samples示例配置和代码以及docker镜像。
Hyperledger Fabric区块链开发教程:
1、安装预编译的Hyperledger Fabric 2.0应用程序
Hyperledger Fabric官方提供了以下2.0版本的预编译程序:
- configtxgen:用于生成Fabric创世区块初始或更新配置文件
 - configtxlator:用于编解码Fabric区块链配置文件
 - cryptogen:用于快速生成节点、用户、客户端等所需的证书和密钥文件
 - discover:用于Fabric网络的服务发现
 - idemixgen:很少用到
 - orderer:Fabric排序节点程序
 - peer:Fabric对等节点程序
 - fabric-ca-client:Fabric-CA服务程序的客户端,用于注册和添加用户
 
首先创建一个Hyperledger Fabric 2.0的专用目录,然后进入
该目录:
~$ mkdir hubwiz-hf2
~$ cd hubwiz-hf2
~/hubwiz-hf2$  
在linux或mac环境下使用如下的命令下载Hyperledger Fabric 2.0的预编译应用:
~/hubwiz-hf2$ curl -sSL https://bit.ly/2ysbOFE | bash -s -d  -- 2.0.0 1.4.4 0.4.18 
其中参数说明如下:
- 2.0.0:表示Hyperledger Fabric的版本号
 - 1.4.4:表示Fabric CA的版本号
 - 0.4.18:表示第三方引用的版本号
 
上述命令执行后,在当前目录的bin子目录下你就可以看到上述程序了:
~/huwbiz-hf2$ ls bin 
别忘了设置PATH环境变量,例如在.bashrc末尾添加:
export PATH=$HOME/hubwiz-hf2/bin:$PATH 
可以使用如下命令验证Hyperledger Fabric预编译程序安装成功:
~$ orderer version 
正常的话,会看到输出orderer排序节点程序的版本号为:2.0.0。
2、安装Hyperledger Fabric 2.0示例程序代码
在Hyperledger Fabric 2.0目录中执行如下命令安装官方提供的示例代码:
~/hubwiz-hf2$ git clone https://github.com/hyperledger/fabric-samples 
上述命令将克隆官方仓库https://github.com/hyperledger/fabric-samples
的主分支,因此你需要在本机安装有git程序。
使用如下命令查看并验证fabric-samples安装成功:
~/hubwiz-hf2$ tree fabric-samples -L 1 -d 
正常的话,应该看到如下的输出显示:
fabric-samples
|- basic-network
|- chaincode-docker-devmode
|- chaincode
|- ci
|- commercial-paper
|- docs
|- fabcar
|- first-network
|- high-throughput
|- interest_rate_swaps
|- off_chain_data
|- scripts
|- test-network 
在Hyperledger Fabric 2.0的fabric-sample中,最主要的变化
是引入了一个新的测试网络test-network,它同时支持使用cryptogen和fabric-ca来生成部署网络所需的密码学资料。
3、预下载Hyperledger Fabric 2.0的docker镜像
可以使用如下命令预下载Hyperledger Fabric 2.0的docker镜像,
这样在进行后续的测试时,会减少一些等待时间。
~/hubwiz-hf2$ curl -sSL https://bit.ly/2ysbOFE | bash -s -b  -- 2.0.0 1.4.4 0.4.18 
由于上述脚本使用docker pull拉取一批镜像,例如peer、orderer等,
因此在本地机器上需要先安装docker。
4、使用test-network测试Hyperledger Fabric 2.0
进入fabric-samples目录启动Hyperledger Fabric 2.0新增加的测试网络test-network:
~/hubwiz-hf2$ cd fabric-samples/test-network
~/hubwiz-hf2/fabric-samples/test-network$ ./network.sh up  
一切顺利的话,可以看到如下输出:
Creating network "net_test" with the default driver
Creating volume "net_orderer.example.com" with default driver
Creating volume "net_peer0.org1.example.com" with default driver
Creating volume "net_peer0.org2.example.com" with default driver
Creating orderer.example.com    ... done
Creating peer0.org2.example.com ... done
Creating peer0.org1.example.com ... done
CONTAINER ID        IMAGE                               COMMAND             CREATED             STATUS                  PORTS                              NAMES
8d0c74b9d6af        hyperledger/fabric-orderer:latest   "orderer"           4 seconds ago       Up Less than a second   0.0.0.0:7050->7050/tcp             orderer.example.com
ea1cf82b5b99        hyperledger/fabric-peer:latest      "peer node start"   4 seconds ago       Up Less than a second   0.0.0.0:7051->7051/tcp             peer0.org1.example.com
cd8d9b23cb56        hyperledger/fabric-peer:latest      "peer node start"   4 seconds ago       Up 1 second             7051/tcp, 0.0.0.0:9051->9051/tcp   peer0.org2.example.com 
恭喜!你的Hyperledger Fabric 2.0已经安装成功了!
关注公众号
					低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 
							
								
								    上一篇
								    
								
								运维进化论:微盟故障给我们的启示
作者简介:茹炳晟,业界知名实战派软件质量和研发工程效能专家,中国商业联合会互联网应用技术委员会智库专家,畅销书《测试工程师全栈技术进阶与实践》的作者,InfoQ 极客时间“软件测试52讲-从小工到专家的实战心法”的专栏作者。现任Dell EMC中国研发集团资深架构师,历任eBay中国研发中心测试基础架构技术负责人,HP软件中国研发中心资深架构师、性能测试专家,Alcatel-Lucent高级技术主管,Cisco中国研发中心资深工程师等职位,具有超过16年的软件研发经验和技术管理经验。 事件背景 微盟是国内移动互联网营销引领者,中国最大的微信公众智能服务平台,基于微信为企业提供开发、运营、培训、推广一体化解决方案,帮助企业实现线上线下互通,社会化客户关系管理,移动电商,轻应用等。 2月23日19点,微盟出现了大规模系统故障,根据官方消息,这是一起运维部门核心员工在生产环境的“删库”操作引发的。截止发稿时,系统目前还处于修复阶段,预计全部恢复将在2月28日晚上24点完成。在这期间,微盟启动紧急响应机制,并在腾讯云的大力支持下一起研究制定生产环境和数据修复方案。 历史上类似的事件 说到“删库...
 - 
							
								
								    下一篇
								    
								
								Kubernetes - 4.4 Workload - Deployment
什么是Deployment? Deployment提供了运行Pod能力,并且为Pod提供滚动升级、伸缩、副本等功能,一般用于运行无状态的应用。目前建议使用Deployment来代替RelicaSet及ReplicationController的使用。 什么是无状态应用? 无状态应用是不将数据或应用程序状态存储到容器中,这将使无状态应用程序更具可伸缩性。例如前端应用是无状态的,可以部署多个副本以提高其可用性并在需求低时进行缩减,并且这些副本不需要唯一的标识。 Deployment操作 创建Deploymentkubectl create deployment nginx-deployment --image=nginx:1.16通过yaml文件操作kubectl apply -f nginx-deployment.yaml apiVersion: apps/v1 kind: Deployment metadata: name: nginx-deployment labels: app: nginx spec: selector: matchLabels: app: nginx templ...
 
相关文章
文章评论
共有0条评论来说两句吧...

			
				
				
				
				
				
				
				
微信收款码
支付宝收款码