FabricHyperledger Fabric

Ubuntu 18 部署 Hyperledger Fabric

2019-04-08  本文已影响103人  bei6

安装 ssh

  1. sudo apt-get update
  2. sudo apt-get install ssh

安装 Go

  1. 下载

Go源码下载 选择对应的平台下载。

  1. 准备

在下载的位置打开 terminal 。

  1. 安装

sudo tar -zxvf goxxxxx.tar.gz -C /usr/local, 建议 /usr/local 位置安装。

  1. 配置

sudo gedit /etc/profile, 追加以下配置到环境变量。

export GOROOT=/usr/local/go
export GOPATH=~/code/go

save and exit.

  1. 测试

source /etc/profile 立即适应新环境

输入 go version,成功查看版本信息杂表示配置成功。

安装 Docker-CE

  1. 前置工作

sudo apt-get update
sudo apt-get install apt-transport-https ca-certificates curl software-properties-common
curl -fsSL https://mirrors.ustc.edu.cn/docker-ce/linux/ubuntu/gpg | sudo apt-key add -
sudo apt-get update

  1. 安装 Docker

sudo apt-get install docker-ce

  1. 将当前用户添加到 Docker Group(支持不使用 sudo 执行 docker 命令)

sudo usermod -aG docker bey

  1. 测试

docker run hello-world,正确输出结果如下:

Hello from Docker!
This message shows that your installation appears to be working correctly.

To generate this message, Docker took the following steps:
 1. The Docker client contacted the Docker daemon.
 2. The Docker daemon pulled the "hello-world" image from the Docker Hub.
    (amd64)
 3. The Docker daemon created a new container from that image which runs the
    executable that produces the output you are currently reading.
 4. The Docker daemon streamed that output to the Docker client, which sent it
    to your terminal.

To try something more ambitious, you can run an Ubuntu container with:
 $ docker run -it ubuntu bash

Share images, automate workflows, and more with a free Docker ID:
 https://hub.docker.com/

For more examples and ideas, visit:
 https://docs.docker.com/get-started/

安装 Docker-Compose

  1. 下载最先版本的 Docker Compose

sudo curl -L https://github.com/docker/compose/releases/download/1.24.0-rc1/docker-compose-uname -s-uname -m-o /usr/local/bin/docker-compose

  1. 给二进制文件添加执行权

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

  1. 查看版本

docker-compose -v

下载 fabric 及其镜像

go get

  1. 可以的话,直接 go get 获取 go get github.com/hyperledger/fabric,如果 go get 命令无法执行,再试试 Git

git clone

  1. 创建目录 mkdir -p $GOPATH/src/github.com/hyperledger/,进入目录 cd $GOPATH/src/github.com/hyperledger/

  2. 克隆 fabric git clone https://github.com/hyperledger/fabric.git,下载完成后,进入 fabric 文件夹

  3. 切换 1.4 版本(可选)

git checkout v1.4.0

快速部署网络

cd $GOPATH/src/github.com/hyperledger/fabric/scripts

./bootstrap.sh

该脚本运行时间较长,主要是在下载 fabrice 各个组件的 docker 镜像

将二进制文件复制到 usr/local/bin 目录

cd $GOPATH/src/github.com/hyperledger/fabric/scripts/fabric-samples/bin

sudo cp -r . /usr/local/bin

这样就可以到处使用这些可执行二进制文件了。

测试

cd $GOPATH/src/github.com/hyperledger/fabric/scripts/fabric-samples/first-network

./byfn.sh down

./byfn.sh up

看到如下信息表示部署成功,恭喜!

========= All GOOD, BYFN execution completed =========== 


 _____   _   _   ____   
| ____| | \ | | |  _ \  
|  _|   |  \| | | | | | 
| |___  | |\  | | |_| | 
|_____| |_| \_| |____/  

解释 bootstrap.sh

打开 bootstrap.sh 文件 大致查看以下内容

总结:

if [ "$SAMPLES" == "true" ]; then
  echo
  echo "Installing hyperledger/fabric-samples repo"
  echo
  samplesInstall
fi
if [ "$BINARIES" == "true" ]; then
  echo
  echo "Installing Hyperledger Fabric binaries"
  echo
  binariesInstall
fi
if [ "$DOCKER" == "true" ]; then
  echo
  echo "Installing Hyperledger Fabric docker images"
  echo
  dockerInstall
fi

1. 安装 hyplerledger fabric-sample

2. 安装 hyplerledger fabric binaries

文件 介绍 类型 依赖
peer 账本(对等)节点程序,负责维护账本数据,执行链码 服务 core.yaml
orderer 共识服务程序,负责打包交易,使用通道订阅给其他账本节点 服务 orderer.yaml
cryptogen 生成 x509标准的证书以及密钥 工具 crypto-config.yaml
configtxgen 生成共识服务启动以及通道创建所需配置数据 工具 configtx.yaml
configtxlator 用来将通道配置信息转换为可读形式 工具
discover fabric discovery 服务的命令行客户端 服务
fabric-ca-client hyperledger fabric 证书认证客户端 工具
idemixgen Hyperledger Fabric 生成关键材料时被用于身份混淆MSP的工具 工具

3. 安装 hyplerledger fabric docker images

打开 fabric-samples/bin/get-docker-images.sh 可以发现,总共下载的镜像包括如下:

镜像 介绍
fabric-peer 账本(对等)节点的镜像
fabric-orderer 共识服务节点的镜像
fabric-ccenv 链码环境镜像
fabric-tools 工具库镜像
fabric-kafka 分布式消息队列镜像
fabric-zookeeper 分布式协调服务镜像
fabric-couchdb 状态存储库镜像
fabric-baseos
上一篇下一篇

猜你喜欢

热点阅读