本地编译Fabric Code

作者: 酷酷de熊 | 来源:发表于2018-04-12 15:12 被阅读0次

    设置go环境变量

    打开~/.bashrc文件, gedit ~/.bashrc

    export GOROOT=/usr/local/go

    export GOPATH=$HOME/go_project

    export PATH=$PATH:$GOROOT/bin:${GOPATH}/bin

    保存,执行source ~/.profile使其生效。

    可以在任意目录下执行go version检查环境变量设置是否成功

    Docker安装

    可以使用阿里提供的镜像,参考:https://yq.aliyun.com/articles/110806

    其中Ubuntu的脚本是:

    # step 1: 安装必要的一些系统工具

    sudo apt-get update

    sudo apt-get -y install apt-transport-https ca-certificates curl software-properties-common

    # step 2: 安装GPG证书

    curl -fsSL http://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -

    # Step 3: 写入软件源信息

    sudo add-apt-repository "deb [arch=amd64] http://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable"

    # Step 4: 更新并安装 Docker-CE

    sudo apt-get -y update

    sudo apt-get -y install docker-ce

    安装完成后需要修改当前用户权限:

    sudousermod -aG docker richard

    注销并重新登录,然后添加阿里云的Docker Hub镜像:

    sudo mkdir -p /etc/docker

    sudo tee /etc/docker/daemon.json <<-'EOF'

    {

      "registry-mirrors": ["https://obou6wyb.mirror.aliyuncs.com"]

    }

    EOF

    sudo systemctl daemon-reload

    sudo systemctl restart docker

    Docker-Compose的安装

    Docker-compose是支持通过模板脚本批量创建Docker容器的一个组件。

    https://github.com/docker/compose/releases中提供了下载命令

    curl -L https://github.com/docker/compose/releases/download/1.21.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-composechmod +x /usr/local/bin/docker-compose

    sudochmod+x /usr/local/bin/docker-compose

    Pip的安装

    Pip是基于Python的一个工具,需要安装Python-pip,运行脚本:

    sudo apt-getinstallpython-pip

    这个脚本会安装Pip所依赖的Python和各种库,所以安装pip完毕后我们也有了Python的环境。运行以下命令可以检查pip和Python的版本:

    pip –V

    apt安装的版本可能不够新,我们使用以下命令可以更新pip版本:

    pip install--upgrade pip

    Go Tools安装

    Fabric使用GO开发,其中用到了一些官方或者第三方的工具,我们也需要下载。尤其是golang的网址被墙了,我们只有访问GitHub的镜像。

    mkdir -p $GOPATH/src/golang.org/x

    cd $GOPATH/src/golang.org/x

    git clone https://github.com/golang/tools.git

    等tools下载完毕,我们可以运行以下命令来安装Fabric可能用到的Go工具:

    go get github.com/kardianos/govendor

    go get github.com/golang/lint/golint

    go get golang.org/x/tools/cmd/goimports

    go get github.com/onsi/ginkgo/ginkgo

    go get github.com/axw/gocov/...

    go get github.com/client9/misspell/cmd/misspell

    go get github.com/AlekSi/gocov-xml

    go get github.com/golang/protobuf/protoc-gen-go

    第三方库安装

    Fabric依赖的第三方库里面,有些库又依赖了其他库,而这些库是需要我们先手动准备好的。比如libltdl-dev,这是PKCS11用到的一个库,我们需要安装:

    sudo apt-get install libltdl-dev

    Fabric源码下载

    我们可以使用Git命令下载源码,首先需要建立对应的目录,然后进入该目录,Git下载源码:

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

    cd $GOPATH/go/src/github.com/hyperledger

    git clone https://github.com/hyperledger/fabric.git

    等Fabric下载完毕后,我们就切换到Fabric源码的文件夹:

    cd $GOPATH/go/src/github.com/hyperledger

    编译Fabric

    编译Fabric的代码主要是通过make命令来完成,

    关于make的基础知识,参考:http://www.ruanyifeng.com/blog/2015/02/make.html

    1.Orderer节点的编译

    Orderer节点容器里面运行的是orderer服务,我们要生成Orderer镜像,

    就需要先编译出Orderer程序。执行:make orderer

    Orderer编译完成后,会把二进制文件放在.build/docker/bin目录下。

    2.Peer节点的编译

    Peer节点的编译因为墙的原因,需要一些额外的操作。另外链码是运行在Peer所在的机器上,所以需要给ChainCode准备运行基础环境,也就是ccenv和javaenv两个镜像。

    在make peer之前我们必须先保证本地没有对应的镜像文件,

    如果有,那么就用docker rmi 命令删除之前下载或者编译好的镜像。

    还记得前面下载的Go Tools吗,这里需要copy到Fabric目录里面来:

    mkdir-p build/docker/gotools/bin

    #此操作只是为了绕开墙

    cp $GOPATH/bin/* build/docker/gotools/bin

    直接运行以下命令即可编译生成Peer节点的Docker镜像:

    make peer

    3.Fabric 工具编译

    Fabric除了Orderer和Peer外,还为我们提供了几个很方便的工具,在搭建Fabric网络时我们就用到过。那就是:configtxgen,cryptogen,configtxlator

    这三个工具的编译也很简单,直接运行以下命令即可:

    make configtxgen

    make cryptogen

    make configtxlator

    4.Docker镜像的生成

    前面三步只是生成了Fabric的二进制文件,我们并不能直接使用,而是需要分别将这些二进制文件打包到Docker镜像中。所以我们接下来需要Build Docker Image。

    要生成Orderer镜像,那么需要运行命令:

    make orderer-docker

    由于没有网络文件的依赖,所以这时应该很快就能完成。然后我们继续生成Peer镜像:

    make peer-docker

    再然后是客户端,也就是fabric-tools,对应的命令是:

    make tools-docker

    以上3个最重要的镜像生成完成,我们可以用

    docker images

    5.其他Docker镜像的编译

    除了上面这些镜像外,实际上我们可能还会用到CouchDB做状态数据库,用Kafka做共识,用Zookeeper做Kafka的高可用支持,这些工具都有对应的Docker镜像,我们仍然可以使用make命令来生成他们。

    运行以下命令,系统会给我们生成一整套的Fabric镜像:

    make docker

    如果我们对之前生成的镜像不满意,对代码进行调整后需要重新生成,可以使用

    make clean

    参考: https://www.cnblogs.com/studyzy/p/8030613.html

    相关文章

      网友评论

        本文标题:本地编译Fabric Code

        本文链接:https://www.haomeiwen.com/subject/vfzxkftx.html