安装 ssh
sudo apt-get update
sudo apt-get install ssh
安装 Go
- 下载
Go源码下载 选择对应的平台下载。
- 准备
在下载的位置打开 terminal 。
- 安装
sudo tar -zxvf goxxxxx.tar.gz -C /usr/local
, 建议 /usr/local
位置安装。
- 配置
sudo gedit /etc/profile
, 追加以下配置到环境变量。
export GOROOT=/usr/local/go
export GOPATH=~/code/go
save and exit.
- 测试
source /etc/profile
立即适应新环境
输入 go version
,成功查看版本信息杂表示配置成功。
安装 Docker-CE
- 前置工作
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
- 安装 Docker
sudo apt-get install docker-ce
- 将当前用户添加到 Docker Group(支持不使用 sudo 执行 docker 命令)
sudo usermod -aG docker bey
- 测试
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
- 下载最先版本的 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
- 给二进制文件添加执行权
sudo chmod +x /usr/local/bin/docker-compose
- 查看版本
docker-compose -v
下载 fabric 及其镜像
go get
- 可以的话,直接 go get 获取
go get github.com/hyperledger/fabric
,如果 go get 命令无法执行,再试试 Git
git clone
创建目录
mkdir -p $GOPATH/src/github.com/hyperledger/
,进入目录cd $GOPATH/src/github.com/hyperledger/
克隆 fabric
git clone https://github.com/hyperledger/fabric.git
,下载完成后,进入 fabric 文件夹切换 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 文件
大致查看以下内容
dockerFabricPull
: 下载 fabric-peer fabric-orderer fabric-ccenv fabric-javaenv fabric-tools 镜像dockerThirdPartyImagesPull
: 下载 couchdb kafka zookeeper 镜像dockerCaPull
: 下载 fabric-ca 镜像samplesInstall
: git clone -b master https://github.com/hyperledger/fabric-samples.gitbinariesInstall
: 安装 hyperledger-fabric hyperledger-fabric-ca 二进制
总结:
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 |