區塊鏈 Hyperledger Fabric v1.0.0 環境搭建


 

前言最近項目涉及到超級賬本,在有些理論知識的基礎上,需要整一套環境來。

這是一個特別要注意的事情,筆者之前按照網絡上推薦,大部分都是推薦ubuntu系統的,於是下載Ubuntu系統(16.04.5和18.04都試試),遇到各種問題,一直不能成功,大概花了好多天,一直不成功,后來都要放棄了,但是心有不甘,又下載centos7,只花了一天,就成功了,所以在這里使用centos7系統。在這個還是要感謝各位大神的博客,感激之情溢於言表。

上個截圖來表達喜悅的心情

 

這是一張成功的截圖。

套話不多說,直接操作步驟。

 

1.下載VirtualBox

版本:5.2.20-125813(下載時最高版本)。

下載地址:https://www.virtualbox.org/

(這么快就更新了一版本嘛,無比尷尬)

具體安裝步驟,百度一下。

 

2.下載鏡像文件  centos.iso

版本號:CentOS-7-x86_64-DVD-1804.iso 和 CentOS-7-x86_64-Everything-1804.iso(筆者都有下載,使用的是CentOS-7-x86_64-Everything-1804)

下載地址:http://isoredirect.centos.org/centos/7/isos/x86_64/(當前連接顯示所有版本及各種鏡像連接)。

http://mirrors.aliyun.com/centos/7.5.1804/isos/x86_64/(筆者選擇的是阿里的鏡像,如果還有迅雷的話,下載十分迅速)。

安裝:https://www.cnblogs.com/hihtml5/p/8217062.html(筆者根據大神提供的經驗,尤其后面網絡設置的,幫了大忙)。

網絡:筆者使用的是有限網絡。

 要保證主機可以ping通虛擬機,同時虛擬機可以ping通‘www.baidu.com’(筆者一直實現不了虛擬機平通主機,但是不影響后續步驟)。

 

3.使用secureCRT連接虛擬機。

說明:筆者不太喜歡'右ctrl'鍵來切換鼠標在虛擬機和主機的位置,就用secureCRT連接虛擬機。其他人可以根據自己的喜歡,自行選擇及忽略,是不是很人性化。

根據第二步驟的操作,主機可以ping通虛擬機,即可連接成功,如果還不行,可修改/etc/sysconfig/network-scripts/ifcfg-enp0s3。

 

登錄虛擬機,筆者所有需要操作都在root用戶,/root/目錄下。之前使用Ubuntu時,就遇到這種情況,也是差些就成功了(惋惜萬分)。

 

 

4.安裝GO

 

4.1 下載go

下載指令:

[root@localhost ~] # wget https://storage.googleapis.com/golang/go1.9.linux-amd64.tar.gz 

如果沒有安裝wget,需要先安裝wget。命令:

[root@localhost ~] # yum install wget  

等待下載完成..

 

4.2 解壓

[root@localhost ~] # sudo tar -C /usr/local -xzf go1.9.linux-amd64.tar.gz

 

4.3配置環境變量 

[root@localhost ~] # vi /etc/profile  

在文件最底部,添加如下內容: 

export PATH=$PATH:/usr/local/go/bin 
export GOROOT=/usr/local/go 
export GOPATH=$HOME/go 
export PATH=$PATH:$HOME/go/bin  

 退出文件,保存生效。

[root@localhost ~] # source /etc/profile

 

4.4驗證

筆者建議使用如下指令,更詳細。

[root@localhost ~] # go env 

效果如下圖,則安裝成功。

 

 

5.安裝docker

由於操作過多,請按照步驟來。

 

5.1查看內河版本,要高於3.10。筆者下載的系統,剛好滿足。查看指令如下:

[root@localhost ~] # uname -r

 

5.2  更新yum包,保證最新的。指令如下:

[root@localhost ~] # sudo yum update

 

5.3移除docker舊版本。(如果是新系統,可以忽略此步驟)。指令如下:

[root@localhost ~] # sudo yum remove docker  docker-common docker-selinux docker-engine

 

5.4 安裝需要的軟件包。操作指令如下:  

[root@localhost ~] # sudo yum install -y yum-utils device-mapper-persistent-data lvm2

 

5.5  設置鏡像資源。指令如下:

[root@localhost ~] # sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

 

5.6  查看倉庫所有docker版本,並選擇特定版本安裝。指令如下(如果沒查詢到可用版本,多試試5.6步驟):

[root@localhost ~] # yum list docker-ce --showduplicates | sort -r

輸出如下圖:

筆者在運行fabric網絡時,就遇到一個問題(具體問題,忘記記錄),百度了一下說是docker和docker-compose版本問題,所以筆者在這里推薦docker版本是:17.12.0-ce。

 

5.7 安裝docker。指令如下:

[root@localhost ~] # sudo yum install 版本號  ## sudo yum install docker-ce-17.12.0.ce

 

5.8 驗證是否安裝成功(client和service都有顯示)。指令如下:

[root@localhost ~] # docker version  

如下顯示:

5.9 啟動 並且 加入開機啟動。指令如下:

[root@localhost ~] # sudo systemctl start docker
[root@localhost ~] # sudo systemctl enable docker

 

5.10 添加阿里的鏡像。指令如下:

[root@localhost ~] # yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

  

6.安裝docker-compose  

 

6.1 筆者使用pip安裝。指令如下:

 [root@localhost ~] # yum -y install epel-release  

這個版本應該是8.*的,安裝docker-compose需要升級到18.*

 

 

6.2安裝組件python-pip。指令如下:

[root@localhost ~] # sudo yum -y install python-pip

 pip

6.3 升級pip版本

[root@localhost ~] # pip install --upgrade pip  

如下圖顯示:

 

6.4  安裝docker-compose。筆者安裝的是1.12.0版本。指令如下:

[root@localhost ~] # sudo pip install docker-compose==版本號 ##sudo pip install docker-compose==1.12.0

 

6.5驗證。指令如下:

[root@localhost ~] # docker-compose version

 

7.docker run hello-world

到此docker和docker-compose已經安裝完成,那么來試試一個hello-world吧。指令如下:

[root@localhost ~] # docker run hello-world  

截圖如下:

 

如果是第一次運行,會有下載hello-world 的過程,請耐心等待。(筆者已經運行過好多次,截圖如上)。

docker 常用指令:

docker stats # 容器,狀態
docker rm -f $(docker ps -aq) #清除容器內所有示例
...

等等(到目前就用到這兩個指令,捂臉..)

 

8. Fabric資源及鏡像下載 

 

8.1 創建文件。如下圖

 

 

8.2 git 下載Fabric。指令如下: 

[root@localhost hyperledger] # git clone https://github.com/hyperledger/fabric.git

如果git不可用,下載git。指令如下:

[root@localhost hyperledger] # sudo yum install git

 

8.3設置資源版本號:v1.0.0

[root@localhost ~] # cd ~/go/src/github.com/hyperledger/fabric
[root@localhost fabric] # git checkout v1.0.0

  

8.4 Fabric Docker 鏡像下載

[root@localhost ~] # cd ~/go/src/github.com/hyperledger/fabric/examples/e2e_cli/
[root@localhost e2e_cli] # source download-dockerimages.sh -c x86_64-1.0.0 -f x86_64-1.0.0  

 

8.5下載完成,查看鏡像文件列表。指令如下:

[root@localhost e2e_cli] # docker images  

如下圖顯示:

 

8.6  啟動 Fabric 網絡環境。指令如下:

[root@localhost e2e_cli] # ./network_setup.sh up  

該腳本啟動的服務解釋如下(摘自網絡):

編譯生成Fabric公私鑰、證書的程序,程序在目錄:fabric/release/linux-amd64/bin

基於configtx.yaml生成創世區塊和通道相關信息,並保存在channel-artifacts文件夾。

基於crypto-config.yaml生成公私鑰和證書信息,並保存在crypto-config文件夾中。

基於docker-compose-cli.yaml啟動1Orderer+4Peer+1CLI的Fabric容器。  

 

稍等一會,出現文章開頭的截圖。再次截取,如果如下圖顯示,那就恭喜,你的網絡也通了。

 

8.7另開session窗口。指令如下:

[root@localhost ~] # docker stats  

容器顯示截圖如下:

 

8.8 網絡關閉

新開session窗口。指令如下(如下指令可以先不執行,后續步驟會用到):

[root@localhost ~] # cd ~/go/src/github.com/hyperledger/fabric/examples/e2e_cli/
[root@localhost e2e_cli] # ./network_setup.sh down

 

9.測試Fabric網絡

 

9.1 新起session窗口,打開客戶端。指令如下:

[root@localhost ~] # docker exec -it cli bash  

進入目錄下,如下圖所示:

 

9.2查詢a賬戶余額.。指令如下:

peer chaincode query -C mychannel -n mycc -c '{"Args":["query","a"]}'

截圖如下顯示:

 

9.3轉賬。a 賬戶給 b 轉 50:

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","a","b","50"]}'

 查詢余額,截圖如下:

a賬號余額:

 

 到此,所有的步驟都結束了,可以執行 “8.7關閉網絡”。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM