前言:最近項目涉及到超級賬本,在有些理論知識的基礎上,需要整一套環境來。
這是一個特別要注意的事情,筆者之前按照網絡上推薦,大部分都是推薦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關閉網絡”。