1.安裝docker
1.1 基礎(chǔ)軟件安裝
# 安裝基本軟件
$ sudo apt-get update
$ sudo apt-get install apt-transport-https ca-certificates curl git software-properties-common lrzsz -y
1.2 添加阿里的docker鏡像倉(cāng)庫(kù)
# 添加阿里的docker鏡像倉(cāng)庫(kù)
$ curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -
$ sudo add-apt-repository "deb [arch=amd64] https://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable"
# 更新軟件源
$ sudo apt-get update
1.3 安裝docker
# 安裝docker
$ sudo apt-get install docker-ce -y
# 查看安裝的docker版本
$ docker version
Client:
Version: 18.06.1-ce
API version: 1.38
Go version: go1.10.3
Git commit: e68fc7a
Built: Tue Aug 21 17:24:51 2018
OS/Arch: linux/amd64
Experimental: false
Got permission denied while trying to connect to the Docker daemon socket at
unix:///var/run/docker.sock: Get
http://%2Fvar%2Frun%2Fdocker.sock/v1.38/version:
dial unix /var/run/docker.sock: connect: `permission denied`
# 當(dāng)前用戶直接操作docker時(shí), 權(quán)限不夠, 需要做下面的第4不操作
1.4 將當(dāng)前用戶添加到docker組
# 將用戶加入該 group 內(nèi)。然后退出并重新登錄就生效啦。
$ sudo gpasswd -a ${USER} docker
# 重啟docker服務(wù)
$ systemctl restart docker
# 當(dāng)前用戶切換到docker群組
$ newgrp - docker
$ docker version
Client:
Version: 18.06.1-ce
API version: 1.38
Go version: go1.10.3
Git commit: e68fc7a
Built: Tue Aug 21 17:24:51 2018
OS/Arch: linux/amd64
Experimental: false
Server:
Engine:
Version: 18.06.1-ce
API version: 1.38 (minimum version 1.12)
Go version: go1.10.3
Git commit: e68fc7a
Built: Tue Aug 21 17:23:15 2018
OS/Arch: linux/amd64
Experimental: false
1.5 安裝docker-compose
#安裝依賴(lài)工具
$ sudo apt-get install python-pip -y
#安裝編排工具
$ sudo pip install docker-compose
#查看版本
$ sudo docker-compose version
2.安裝go語(yǔ)言
#安裝包下載地址:
https://golang.org/dl/ - 翻墻
https://studygolang.com/dl - 國(guó)內(nèi)鏡像源
如果沒(méi)有進(jìn)行安裝包下載, 可直接終端中使用如下命令進(jìn)行安裝(目前最新版本):
# 1. 使用wget工具下載安裝包
$ wget https://dl.google.com/go/go1.11.linux-amd64.tar.gz
# 2. 解壓tar包到/usr/local
$ sudo tar zxvf go1.11.linux-amd64.tar.gz -C /usr/local
# 3. 創(chuàng)建Go目錄
$ mkdir $HOME/go
# 4. 用vi打開(kāi)~./bashrc,配置環(huán)境變量
$ vim ~/.bashrc
# 5. 增加下面的環(huán)境變量需纳,保存退出
export GOROOT=/usr/local/go
export GOPATH=$HOME/go
export PATH=$PATH:$GOROOT/bin:$GOPATH/bin
# 6. 使環(huán)境變量立即生效, 一些命令二選一
$ source ~/.bashrc
$ . ~/.bashrc
# 7. 檢測(cè)go是否安裝好
$ go version
3.安裝Node.js
3.1官方下載地址
https://nodejs.org/en/download/
3.2下載二進(jìn)制源碼包
$ wget https://nodejs.org/dist/v8.11.4/node-v8.11.4-linux-x64.tar.xz
3.3解壓并安裝
# 指定壓縮包解壓到/opt目錄下
$ sudo tar xvf node-v8.11.4-linux-x64.tar.xz -C /opt
- 在/opt目錄下得到 node-v8.11.4-linux-x64 目錄
3.4將node.js設(shè)置為全局可用
# 打開(kāi)系統(tǒng)級(jí)別的配置文件 /etc/profile
$ sudo vim /etc/profile
# 添加如下配置項(xiàng), 保存退出
export NODEJS_HOME=/opt/node-v8.11.4-linux-x64
export PATH=$PATH:$NODEJS_HOME/bin
# 重新加載配置文件
$ . /etc/profile
/etc/profile -> 設(shè)置環(huán)境變量的配置文件
- 對(duì)當(dāng)前系統(tǒng)下所有用戶生效
3.5測(cè)試
$ node -v
4.部署hyperledger Fabric
4.1下載并執(zhí)行fabric的引導(dǎo)腳本bootstrap.sh
# 參考資料
https://hyperledger-fabric.readthedocs.io/en/release-1.4/install.html
# 創(chuàng)建放置的目錄,然后進(jìn)入該目錄颜价,用curl下載腳本尤溜。
$ cd ~ # 這里在家目錄下創(chuàng)建放置目錄
$ mkdir hyperledger-fabric # 創(chuàng)建放置目錄
$ cd hyperledger-fabric
# 下載并執(zhí)行腳本, [ ***語(yǔ)法格式*** ]如下:
$ curl -sSL http://bit.ly/2ysbOFE | bash -s <fabric> <fabric-ca> <thirdparty>
- fabric: fabric的版本
- fabric-ca: fabric-ca的版本
- thirdparty: 第三方庫(kù)的版本
# 下載并執(zhí)行腳本, [ ***需要翻墻, 需要翻墻, 需要翻墻, 需要翻墻, 需要翻墻,*** ]
$ curl -sSL http://bit.ly/2ysbOFE | bash -s 1.2.1 1.2.1 0.4.10
- http://bit.ly/2ysbOFE: 該地址必須翻墻才能訪問(wèn)
# ***不翻墻的方式***
$ curl -sSL https://raw.githubusercontent.com/hyperledger/fabric/master/scripts/bootstrap.sh | bash -s 1.2.1 1.2.1 0.4.10
# 該腳本啟動(dòng)之后會(huì)下載兩個(gè)壓縮包和一些鏡像文件, 整個(gè)過(guò)程會(huì)比較長(zhǎng), 耐心等待...
# 1. hyperledger-fabric-linux-amd64-1.2.0.tar.gz
# 2. hyperledger-fabric-ca-linux-amd64-1.2.0.tar.gz
以上兩個(gè)壓縮包下載下來(lái)之后會(huì)被解壓, 解壓目錄:
~/hyperledger-fabric/fabric-samples
可以將事先下載好的兩個(gè)壓縮包放到該目錄下, 提高下載速度 (強(qiáng)烈建議), 放好之后再重新執(zhí)行上邊的curl命令
通過(guò)上述操作拉取的docker鏡像為:
鏡像文件名稱(chēng) | 用途 |
---|---|
hyperledger/fabric-peer | peer模塊鏡像文件 |
hyperledger/fabric-orderer | orderer節(jié)點(diǎn)庫(kù)鏡像文件 |
hyperledger/fabric-ccenv | Go語(yǔ)言chaincode運(yùn)行環(huán)境庫(kù)鏡像文件 |
hyperledger/fabric-tools | 相關(guān)工具鏡像文件包含了cryptogen, configtxgen等工具 |
hyperledger/fabric-ca | CA模塊鏡像文件 |
hyperledger/fabric-couchdb | couchdb數(shù)據(jù)庫(kù)鏡像文件 |
hyperledger/fabric-kafka | kafka庫(kù)鏡像文件 |
hyperledger/fabric-zookeeper | zookeeper庫(kù)鏡像文件 |
4.2設(shè)置全局訪問(wèn)
# 進(jìn)入到 ~/hyperledger-fabric/fabric-samples/bin 目錄
$ cd ~/hyperledger-fabric/fabric-samples/bin
$ ~/hyperledger-fabric/fabric-samples/bin$ tree
.
├── configtxgen
├── configtxlator
├── cryptogen
├── discover
├── fabric-ca-client
├── get-docker-images.sh
├── idemixgen
├── orderer
└── peer
# 將這些二進(jìn)制文件拷貝到 /usr/local/bin 目錄下
$ sudo cp * /usr/local/bin
# 執(zhí)行完上述操作之后, fabric的這些可執(zhí)行程序就可以在全局范圍內(nèi)使用了
5.First-Network 環(huán)境測(cè)試
5.1生成相應(yīng)文件
執(zhí)行 ./byfn.sh generate 命令生成相應(yīng)的文件
$ cd ~/hyperledger-fabric/fabric-samples/first-network/
$ ./byfn.sh generate
5.2啟動(dòng)網(wǎng)路
執(zhí)行 ./byfn.sh up 啟動(dòng)網(wǎng)絡(luò)
# byfn == build your first network
$ ./byfn.sh up
當(dāng)我們看到START的時(shí)候即硼,表示啟動(dòng)成功彬向。
...
執(zhí)行結(jié)束兼贡,顯示END
5.3停止網(wǎng)絡(luò)
通過(guò)docker ps命令可以查看到節(jié)點(diǎn)的啟動(dòng)情況。
$ docker ps
如果我們要停止網(wǎng)絡(luò)娃胆,可以執(zhí)行./byfn.sh down 命令來(lái)停止
$ ./byfn.sh down