分享
  1. 首页
  2. 文章

Linux搭建Hyperledger Fabric v1.1.0

理论上的老班长 · · 1154 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

  1. 安装依赖
sudo apt-get update
sudo apt-get install apt-transport-https ca-certificates curl software-properties-common git make gcc
  1. 使用国内的阿里源安装docker

当然也可以使用别的源,因为我的是阿里服务器,所以就选国内源了,其它源百度都有的。

curl -fsSL http://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -
add-apt-repository "deb [arch=amd64] http://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable"
sudo apt-get -y update
sudo apt-get install docker-ce
  1. 添加阿里云镜像
sudo mkdir -p /etc/docker
vim /etc/docker/daemon.json
daemon.json中添加下面内容
{
 "registry-mirrors" : ["https://obou6wyb.mirror.aliyuncs.com"] 
}
  1. 重启docker服务
service docker restart
  1. 安装docker-compose
curl -L https://get.daocloud.io/docker/compose/releases/download/1.21.2/docker-compose-`uname -s`-`uname -m`>/usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
docker-compose version
  1. 下载golang
wget https://studygolang.com/dl/golang/go1.10.1.linux-amd64.tar.gz
  1. 解压golang到/usr/local
tar -zxvf go1.10.1.linux-amd64.tar.gz -C /usr/local
  1. 配置环境变量
mkdir go
vim /etc/profile
# 定位profile到最下面,添加下面的环境变量
export GOPATH=~/go
export PATH=$PATH:/usr/local/go/bin
# 使环境变量生效
source /etc/profile
# 查看go的版本
go version
  1. 安装Node.js和NPM
wget https://npm.taobao.org/mirrors/node/v8.11.2/node-v8.11.2-linux-x64.tar.xz
mkdir node
tar xvf node-v*.tar.?z --strip-components=1 -C ./node
rm -rf node-v*
mkdir node/etc
echo 'prefix=/usr/local' > node/etc/npmrc
sudo mv node /opt/
sudo chown -R root: /opt/node
sudo ln -s /opt/node/bin/node /usr/local/bin/node
sudo ln -s /opt/node/bin/npm /usr/local/bin/npm
node -v
npm -v
  1. 查看当前python版本

2.7, npm install需要

python --version
  1. hyperledger fabric下载
mkdir -p ~/go/src/github.com/hyperledger
cd ~/go/src/github.com/hyperledger/
git clone https://github.com/hyperledger/fabric.git
cd ~/go/src/github.com/hyperledger/fabric/
# 切换分支
git checkout v1.1.0
  1. hyperledger fabric docker镜像下载
cd ~/go/src/github.com/hyperledger/fabric/examples/e2e_cli/
source download-dockerimages.sh -c x86_64-1.1.0 -f x86_64-1.1.0
docker pull hyperledger/fabric-kafka:latest
docker pull hyperledger/fabric-zookeeper:latest
# 查看镜像
docker images
  1. 运行例子:e2e_cli

注意:修改示例源代码中的一个错误(少了一个下划线)

cd ~/go/src/github.com/hyperledger/fabric/examples/e2e_cli/base/
vim peer-base.yaml

将以下内容:
- CORE_VM_DOCKER_HOSTCONFIG_NETWORKMODE=e2ecli_default

修改为:
- CORE_VM_DOCKER_HOSTCONFIG_NETWORKMODE=e2e_cli_default

运行示例
cd ~/go/src/github.com/hyperledger/fabric/examples/e2e_cli/
./network_setup.sh up

运行的过程很长,当看到start-e2e的时候说明已经开始启动,当看到end-e2e的时候说明启动完成了。

image
image
  1. 查看容器
docker ps
  1. 查询测试
# 打开命令行 关联cli节点
docker exec -it cli bash
# 查询a账户余额
peer chaincode query -C mychannel -n mycc -c '{"Args":["query","a"]}'
# 查询b账户余额
peer chaincode query -C mychannel -n mycc -c '{"Args":["query","b"]}'
  1. 转账测试
# b向a转账30
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","b","a","30"]}'
  1. 关闭fabric网络,结束测试
cd ~/go/src/github.com/hyperledger/fabric/examples/e2e_cli/
./network_setup.sh down

说明:本次环境是在阿里云部署,阿里云可能会有些小问题,最后一通折腾终于解决了,解决方法如下:

# 添加环境变量
vim /etc/profile
# 复制如下,保存在profile中
GODEBUG=netdns=go
# 使profile生效
source /etc/profile
image
# /etc/resolv.conf 注释掉options
cd /etc/resolv.conf
nameserver 127.0.0.11
#options timeout:2 attempts:3 rotate single-request-reopen ndots:0 
image

有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:理论上的老班长

查看原文:Linux搭建Hyperledger Fabric v1.1.0

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
1154 次点击
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏