前提环境:乌班图20.04环境

安装所需要的工具

先配置一下代理源为阿里云代理:

sudo apt-get update  更新源 sudo apt-get install ssh 安装远程客户端sudo apt-get install curl 安装命令行工具sudo apt-get install git 安装gitsudo apt-get install gcc 安装gccsudo apt-get install vim 安装vim文件编辑器sudo apt-get install make 安装makesudo apt-get install net-tools 安装网络工具sudo apt-get install mousepad 安装mousepad 类似于windows的记事本

安装过程就不举例了。

安装完工具后,开始安装go语言:

wget https://studygolang.com/dl/golang/go1.17.1.linux-amd64.tar.gz

将go文件安装包解压到目录/opt/local下面,输入解压命令:

sudo tar -C /usr/local -xzf go1.17.1.linux-amd64.tar.gz

接下来设置用户的环境变量:

输入命令:sudo vim ~/.profile,如图设置环境变量。

设置环境变量输入

export PATH=$PATH:/usr/local/go/binexport GOROOT=/usr/local/goexport GOPATH=/opt/gopath

然后输入命令:source ~/.profile,载入环境变量到这里面。

最后输入命令:go version,查看go是否安装成功

然后输入 sudo reboot 重启虚拟机

Docker的安装

输入命令:sudo apt-get install docker.io来安装docker

输入命令:sudo usermod -aG docker+用户名(我的是ls

注销并重新登录(我的是重启即可 输入:sudo reboot ),然后添加阿里云的Docker Hub镜像:

sudo mkdir -p /etc/dockersudo tee /etc/docker/daemon.json <<-'EOF'{  "registry-mirrors": ["https://obou6wyb.mirror.aliyuncs.com"]}EOF

接着输入如下命令:

sudo systemctl daemon-reloadsudo systemctl restart docker

输入docker version查看docker的版本信息

Docker-Compose的安装

curl -L https://get.daocloud.io/docker/compose/releases/download/1.25.5/docker-compose-`uname -s`-`uname -m` > ~/docker-composesudo mv ~/docker-compose /usr/local/bin/docker-compose chmod +x /usr/local/bin/docker-compose

检查版本docker-compose version 如下图

fabric2.4.4环境搭建

sudo mkdir -p $GOPATH/src/github.com/hyperledger 

进入相对应的目录,输入命令:

cd $GOPATH/src/github.com/hyperledger

然后从网上下载fabric源码,执行命令:

首先先给GPATH路径解锁:

sudo chmod -R 777 $GOPATH 
git clone https://github.com/hyperledger/fabric.git

注意:由于Fabric一直在更新,所有我们并不需要最新最新的源码,需要切换到v1.4.0版本的源码即可:cd /opt/gopath/src/github.com/hyperledger/fabric 进入fabric目录

git checkout v1.4.0

如果你有需要进行fabric对于版本的测试,请自行选择fabric的版本,如果不切换,默认是最新版本的fabric版本。

进入fw@fw-virtual-machine:/opt/gopath/src/github.com/hyperledger/fabric/scripts

目录下:

输入./bootstrap.sh进行脚本的下载:

这是下载bin文件和fabric-ca的bin文件。

之后会拉取对应版本的fabric镜像:

等待镜像拉取完成!

下载完成后可以看到列出的镜像:

我们进行官方demo的测试:

进入如下文件夹:

首先配置一下go的代理:

Goproxy.cn

在终端执行:

go env -w GO111MODULE=ongo env -w GOPROXY=https://goproxy.cn,direct

开启测试网络:

如果想要同时启动CA服务器和couchdb,执行这条指令:

./network.sh up createChannel -ca -s couchdb

如果想仅仅启动couchdb,输入:

./network.sh up createChannel -s couchdb

输入 docker ps:

可以看到测试网络已经启动成功了。

下面进行官方链码的测试:

./network.sh deployCC -ccn basic -ccp ../asset-transfer-basic/chaincode-go -ccl go

链码文件夹:

显示安装链码成功了!

查看链码容器也起来了!

配置一下环境变量:

以org1的组织管理员身份去操作链码:

export PATH=${PWD}/../bin:$PATHexport FABRIC_CFG_PATH=$PWD/../config/export CORE_PEER_TLS_ENABLED=trueexport CORE_PEER_LOCALMSPID="Org1MSP" export CORE_PEER_TLS_ROOTCERT_FILE=${PWD}/organizations/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/ca.crtexport CORE_PEER_MSPCONFIGPATH=${PWD}/organizations/peerOrganizations/org1.example.com/users/Admin@org1.example.com/mspexport CORE_PEER_ADDRESS=localhost:7051

初始化链码:

peer chaincode invoke -o localhost:7050 --ordererTLSHostnameOverride orderer.example.com --tls --cafile "${PWD}/organizations/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem" -C mychannel -n basic --peerAddresses localhost:7051 --tlsRootCertFiles "${PWD}/organizations/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/ca.crt" --peerAddresses localhost:9051 --tlsRootCertFiles "${PWD}/organizations/peerOrganizations/org2.example.com/peers/peer0.org2.example.com/tls/ca.crt" -c '{"function":"InitLedger","Args":[""]}'

因为我们开启了couchdb,我们在输入网址:localhost:5984/_utils

用户名和密码一般默认是: admin和adminpw 如果遗忘可以在docker-compose配置文件中找到

可以看到已经存入了值,是以k-v的形式保存的世界状态。

也可以进入gateway文件夹,利用gateway(高级GO-SDK)进行对区块链底层账本的访问。

具体gateway的重写以后再写一个文章具体说一下如何利用重写的gateway和自己写的链码进行调用。