分享

超级账本Fabric开发实战之环境搭建



问题导读:

1.怎样安装Linux系统?
2.怎样安装Docker?
3.怎样安装Fabric?






在刚开始接触Hyperledger时,非常迷茫,不知道从何入手。导师建议我别只看理论知识,试着在机器上运行一下,边用边学。于是开始在网上各种查怎么搭建Fabric环境,菜鸟(非计算机本科)第一次装虚拟机,用linux,指令也是边查边用,终于花了近五天时间搭建成功,过程艰难。所以写下此教程,让后面学习的同学少走弯路。


1. 安装Linux系统 建议Ubuntu 16.04


关于是使用虚拟机还是双系统,我的笔记本用的虚拟机,实验室台式电脑装得双系统。两种都体验过之后,建议大家还是最好双系统。其实Ubuntu的界面很友好,就算完全不会Linux指令(比如我),基本操作还是能完成的,而且使用起来更直接。


虚拟机教程:(1)下载最新的VirtualBox或者VM ware。(2)下载Ubuntu 16.04 镜像,按着步奏导入就好。网上很多装虚拟机安装教程。跟着做准没错


2. 保证apt source是国内的

输入下面指令:


sudo vi /etc/apt/sources.list


查看apt源列表,如果其中看到是http://us.xxxxx之类的,那么就是外国的,如果看到是http://cn.xxxxx之类的,那么就不用换的。


如果是us,原教程方法是在命令模式下,输入:


:%s/us./cn./g


批量替换,然后输入:wq 保存退出。


*tips:* 我这里提供一个简单的方法,打开系统设置,选择软件和更新


20171026172005765.png


然后在下载自:中选择aliyun,如下图。这样源文件也是在国内。


20171026172300418.png


更新一下源sudo apt-get update


然后安装ssh,这样接下来就可以用Xshell或者SecureCRT之类的客户端远程连接Ubuntu。


[mw_shl_code=shell,true]sudo apt-get install ssh
[/mw_shl_code]


3. go的安装

Ubuntu的apt-get自带的go版本太低,这里我们重新安装,输入指令:


wget https://storage.googleapis.com/golang/go1.9.linux-amd64.tar.gz


然后解压:


sudo tar -C /usr/local -xzf go1.9.linux-amd64.tar.gz


接下来编辑当前用户的环境变量


vi ~/.profile


在最后添加以下内容


[mw_shl_code=shell,true]export PATH=$PATH:/usr/local/go/bin
export GOROOT=/usr/local/go
export GOPATH=$HOME/go
export PATH=$PATH:$HOME/go/bin[/mw_shl_code]


如图


20171026175531629.png


:wq 保存并退出


最后载入环境变量


source ~/.profile


我们把go的目录GOPATH设置在当前用户的文件夹下,所以记得要创建go文件夹


cd ~ 回到根目录


mkdir go 创建go文件夹


go环境安装完成!!


4.Docker的安装

更新一下:这里也可以直接去看docker的官方文档下载,很多人反应这个源挂了,我也试了一下确实下不全,所以下面方法不行的话就去官网下载。(更新时间2018.6.20)


按照深蓝居教程,docker的安装,我使用的是阿里提供的镜像,安装指令如下


curl -sSL http://acs-public-mirror.oss-cn- ... ker-engine/internet | sh -


然后修改当前用户的权限


sudo usermod -aG docker XXX


注销并重新登录,然后添加阿里云的Docker Hub镜像:


建立docker文件 sudo mkdir -p /etc/docker


[mw_shl_code=shell,true]
sudo gedit /etc/docker/daemon.json
{
"registry-mirrors": ["https://obou6wyb.mirror.aliyuncs.com"]
}
保存并退出[/mw_shl_code]


[mw_shl_code=shell,true]sudo systemctl daemon-reload
sudo systemctl restart docker[/mw_shl_code]


最后 docker version 结果如下则成功。


20171026190426611.png


docker安装完成!!


*tips* 后来在给台式机装docker和其他人装的时候,发现这一步总出问题,不是连接网址失败,就是没有添加到组,或者是后面几步提示路径不对。解决办法有解决Docker启动服务器链接失败-Job for docker.service failed because the control process exited error code,或者给用户root权限操作,添加到组,注销再登录即。要是还不行,就放弃阿里换DaoCloud。


5.Docker-Compose的安装

Docker-compose是支持通过模板脚本批量创建Docker容器的一个组件。在安装Docker-Compose之前,需要安装Python-pip,运行指令:


sudo apt-get install python-pip


然后安装docker-compose,考虑到国内外墙的原因,为了下载速度更快,我们选择从DaoClound安装Docker-compose,运行指令:


curl -L https://get.daocloud.io/docker/c ... 2.0/docker-compose-uname -s-uname -m> ~/docker-compose


sudo mv ~/docker-compose /usr/local/bin/docker-compose


chmod +x /usr/local/bin/docker-compose


官方推荐为1.8.0版本以上,这里我们下载的是1.12.0。


查看docker-compose version 如下,docker-compose 安装成功!!


20171026192503643.png


要是上面方法不行,还有一种方法就是直接sudo pip install docker-compose 效果一样(更新)


6.Fabric源码下载

首先建好存放源码的文件夹(也可手动建)路径如下:


mkdir –p ~/go/src/github.com/hyperledger


cd ~/go/src/github.com/hyperledger


用git命令下载完整源码


git clone https://github.com/hyperledger/fabric.git


*tips* Fabric代码一直在更新,以后如果只想下载最新的代码,可以通过–single-branch -b master –depth 1 命令选项来只获取master分支最新的代码。


由于我们只是在搭建环境。不需要最新的代码,所以只需要切换到v1.0.0大版本就行。


cd ~/go/src/github.com/hyperledger/fabric 进入fabric目录


git checkout v1.0.0


Fabric源码下载完成!!


7. Fabric Docker镜像的下载

之前我们已经设置了Docker Hub镜像地址,所以下载也会很快。运行指令


cd ~/go/src/github.com/hyperledger/fabric/examples/e2e_cli/

[mw_shl_code=shell,true]source download-dockerimages.sh -c x86_64-1.0.0 -f x86_64-1.0.0[/mw_shl_code]


这样就可以下载所有需要的Fabric Docker镜像了。由于我们设置了国内的镜像,所以下载应该是比较快的。


下载完毕后,我们运行以下命令检查下载的镜像列表:


docker images


结果如下图


20171026195419555.png


其每个镜像的主要功能就不一一列举了,具体可看《区块链原理,设计与应用》这本书,讲的还是很详细的。


8.启动Fabric网络并完成ChainCode的测试

现在还停留在e2e_cli文件中(如果没有先进入),这里提供了启动、关闭Fabric网络的自动化脚本。我们要启动Fabric网络,并自动运行Example02 ChainCode的测试,执行一个命令:

./network_setup.sh up


这个指令具体进行了如下操作:


编译生成Fabric公私钥、证书的程序,程序在目录:fabric/release/linux-amd64/bin


基于configtx.yaml生成创世区块和通道相关信息,并保存在channel-artifacts文件夹。


基于crypto-config.yaml生成公私钥和证书信息,并保存在crypto-config文件夹中。


基于docker-compose-cli.yaml启动1Orderer+4Peer+1CLI的Fabric容器。


在CLI启动的时候,会运行scripts/script.sh文件,这个脚本文件包含了创建Channel,加入Channel,安装Example02,运行Example02等功能。

  
稍等一会以后,会看见这个界面,那就恭喜啦,整个Fabric网络已经通了 ,


20171026201443658.png


ctrl+c退出


启动成功!!


9.手动测试Fabric网络

这里有官方提供的小例子,在官方例子中,channel名字是mychannel,链码的名字是mycc。


首先进入CLI,然后重新打开一个命令行窗口,输入:


docker exec -it cli bash


这时用户为root@748dafdc900b,在/opt/gopath/src/github.com/hyperledger/fabric/peer目录下,运行以下命令可以查询a账户的余额:


peer chaincode query -C mychannel -n mycc -c '{"Args":["query","a"]}'


20171026202602184.png


方框内可以看见余额为:90


下面我们可以进行转账操作,操作为invoke ,由a转b 50:


peer chaincode invoke -o orderer.example.com:7050 --tls true --cafile /opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem -C mychannel -n mycc -c '{"Args":["invoke","a","b","50"]}'


现在转账完毕, 我们试一试再查询一下a账户的余额,重复之前的查询指令,结果为:


20171026203227277.png


结果正确,a的余额只有40了。


最后,我们需要关闭Fabric,这里先使用exit命令退出cli容器。


exit


然后类似于启动指令:


cd ~/go/src/github.com/hyperledger/fabric/examples/e2e_cli


./network_setup.sh down


20171026204159863.png


到这,我们整个Fabric的环境已经测试完毕!!去做研究或者开发吧!!!




来源: csdn

作者: wangweicai777


原文链接:区块链之Hyperledger(超级账本)Fabric v1.0 的环境搭建(超详细教程)

本帖被以下淘专辑推荐:

已有(1)人评论

跳转到指定楼层
美丽天空 发表于 2018-7-16 09:28:32
不错,学习了
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

推荐上一条 /2 下一条