CentOS 7.1上部署Hyperledger/Fabric 0.6

前端之家收集整理的这篇文章主要介绍了CentOS 7.1上部署Hyperledger/Fabric 0.6前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
好久没写博客,所以想写点东西,转产品经理后就很少研究编码,但技术不能荒废,对于金融科技这行,不仅要懂点金融还要懂技术和产品.......区块链是金融科技很火的技术之一,国内以"以太坊ETH”和“超级账本Hyperledger” 两大阵营为主。ETH发展了好几年,部署、开发环境成熟,而超级账本1.0正式版还没出来,入门还是有点难度。本文主要讲解Hyperledger的Fabric 0.6版本的部署与跑Demo,雷同网上大多数文章,大家入门都是讲这些。@H_404_11@ 由于要用docker,docker在国内被墙得厉害,你们也懂的,建议到淘宝购买香港VPS,系统选择cent os 7.1。@H_404_11@

使用Putty连上服务器后,执行以下命令,做好部署前的准备。

  1. #centos 7.1安装docker
  2. rpm -Uvh http://dl.Fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm
  3. yum -y install docker-io
  4. service docker start
  5. # 开机自动启动
  6. chkconfig docker on
  7. docker run hello-world
  8.  
  9. #安装docker-compose
  10. yum -y install epel-release
  11. yum install python-pip
  12. pip install --upgrade pip
  13. pip install docker-compose
  14. docker-compose version
  15.  
  16. #安装nodejs:
  17. yum install nodejs
  18. node -v
  19. npm -v
  20.  
  21. #搭建Go语言环境
  22. #如果是mini版CentOS,还要先安装wget
  23. yum install wget
  24. wget http://www.golangtc.com/static/go/1.8/go1.8.linux-amd64.tar.gz
  25. #将软件安装在目录/usr/local下
  26. tar -C /usr/local -xzf go1.8.linux-amd64.tar.gz
  27. #在/opt下面新建gopath目录,其中有3个子目录src、pkg、bin
  28. cd /opt;mkdir gopath;cd gopath
  29. mkdir src;mkdir pkg;mkdir bin;
  30.  
  31. #修改环境变量配置文件
  32. yum install vim
  33. vim ~/.bashrc
在. bashrc文件尾部添加以下命令:

  1. export PATH=$PATH:/usr/local/go/bin;
  2. export GOPATH=/opt/gopath;
使用“:wq”退出vim并保存修改

  1. #命令生效 运行
  2. source ~/.bashrc
  3. #测试go语言环境是否安装成功
  4. go version
准备工作已经搞定,接下来开始部署Fabric

0.6版比1.0简单些,我们这里用到peer,baseimage,membersrvc3个镜像。@H_404_11@

  1. docker pull hyperledger/fabric-peer
  2. docker pull hyperledger/fabric-membersrvc
  3. docker pull hyperledger/fabric-baseimage:x86_64-0.3.0
  4.  
  5. #修改Tag为latest
  6. docker tag hyperledger/fabric-baseimage:x86_64-0.3.0 hyperledger/fabric-baseimage:latest
  7. #查看pull下来的镜像
  8. docker images
@H_404_11@

使用 yeasy提供的很好的HyperLedger的模板
  1. git clone https://github.com/yeasy/docker-compose-files
  2. #进入Git下载下来的Docker-compose目录
  3. cd docker-compose-files/hyperledger/0.6/pbft/
文件夹里提供了多种启动节点的方式
4-peers.yml 非安全模式 没有权限认证 启动4个 PBFT peer 节点
4-peers-with-explorer.yml : 启动 4 个 PBFT peer 节点 + 1 个 Blockchain-explorer,可以通过 Web 界面监控集群状态。
4-peers-with-membersrvc.yml:安全模式, 启动 4 个 P BFT peer 节点 + 1 个 CA 节点,并启用 CA 功能
4-peers-with-membersrvc-explorer.yml : 启动 4 个 PBFT peer 节点 + 1 个 CA 节点 + 1 个 Blockchain-explorer,并启用 CA 功能
  1. #我们选择最简单的
  2. docker-compose -f 4-peers.yml up
系统开始打出日志

@H_404_11@日志不断滚动,而且没有报error 或者 exit就表示成功跑起了,接下来是跑Fabric的example2@H_404_11@

打开新的Putty,连接到pbft_vp0_1里面去
  1. docker exec -it pbft_vp0_1 bash
进入容器后,就可以部署 Example02到Fabric上,也就是智能合约可以发布区块链里面了,使用deploy命名
  1. peer chaincode deploy -p github.com/hyperledger/fabric/examples/chaincode/go/chaincode_example02 -c '{"Function":"init","Args": ["a","100","b","200"]}'
@H_404_11@
@H_404_11@
这个example演示两个账户a和b,a有余额100元,b有余额200元,并返回了ChainCode:@H_404_11@ee5b24a1f17c356dd5f6e37307922e39ddba12e5d2e203ed93401d7d05eb0dd194fb9070549c5dc31eb63f4e654dbd5a1d86cbb30c48e3ab1812590cd0f78539 @H_404_11@
下面我们把这个ID放入一个变量中,并查询一下a账户的余额,使用query命令:
  1. CC_ID="ee5b24a1f17c356dd5f6e37307922e39ddba12e5d2e203ed93401d7d05eb0dd194fb9070549c5dc31eb63f4e654dbd5a1d86cbb30c48e3ab1812590cd0f78539"
  2. peer chaincode query -n ${CC_ID} -c '{"Function": "query","Args": ["a"]}'
@H_404_11@
@H_404_11@
我们让a给b转账10元,使用invoke命令:
  1. peer chaincode invoke -n ${CC_ID} -c '{"Function": "invoke","10"]}'
@H_404_11@
查询a账户的余额
  1. peer chaincode query -n ${CC_ID} -c '{"Function": "query","Args": ["a"]}'

猜你在找的CentOS相关文章