美文网首页
hyperledger 区块链 环境搭建与测试

hyperledger 区块链 环境搭建与测试

作者: HT_Jonson | 来源:发表于2017-02-10 16:13 被阅读0次

    1.1 Fabric介绍

    Fabric是数字事件(交易)的账簿,这个账簿由多个参与者共享,每个参与者都在系统中拥有权益。账簿只有在所有参与者达成共识的情况下才能够更新,并且信息一旦记录就永远不能修改。每个记录的事件都可以基于参与者的共识证明使用密码学进行验证。

    交易是安全、私有和保密的。每个参与者使用身份证明向网络成员服务(membership service)注册以获取系统的访问权限。参与者使用不可追踪的导出证书生成交易,可以在网络中完全匿名。交易的内容使用由密钥导出的复杂函数进行加密,确保只有指定的参与者才能够看到内容,以保护商业交易的机密性。

    1.2 使用Fabic的原因

    早期的区块链技术能够实现一些功能,但是缺乏对特定行业需求的完整支持。为了满足现代市场的要求,fabric面向行业需求进行设计以适应多种行业特定的应用场景,并且在诸如伸缩性设计等方面比这个领域的先驱更进一步。Fabric使用了新的方法实现了授权网络、在多个区块链网络上的私有性和保密性。

    以上做了简单的介绍,下面我们就开始搭建环境.
    搭建环境目前我知道的有2种,有一种我没有搭建起来,这里只介绍一种方式吧

    一、安装docker

    执行代码如下:

    curl -sSL https://get.daocloud.io/docker | sh
    

    安装完成后,查看安装情况:

    docker -v
    
    Paste_Image.png

    查看docker的安装目录:

    whereis docker
    
    Paste_Image.png

    修改docker服务配置(/usr/bin/docker 文件)

    vi /usr/bin/docker
    

    把以下配置文件复制到服务配置文件里:

    DOCKER_OPTS="$DOCKER_OPTS -H [tcp://0.0.0.0:2375](tcp://0.0.0.0:2375) -H [unix:///var/run/docker.sock](unix:///var/run/docker.sock) --api-cors-header='*'"
    

    重启docker服务

    sudo service docker restart
    

    二、安装docker-compose

    先安装python-pip,具体安装步奏如下:
    1.首先安装epel扩展源:

    sudo yum -y install epel-release
    

    2.然后安装python-pip

    sudo yum -y install python-pip
    

    3.安装完成后,清除以下缓存 cache

        
    sudo yum clean all
    

    下面开始安装docker-compose
    1.安装docker-compose:

    curl -L https://get.daocloud.io/docker/compose/releases/download/1.9.0/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
    

    2.查看安装情况:

    Paste_Image.png

    配置以下docker镜像加速,目的是下载镜像速度更快:

    curl -sSL https://get.daocloud.io/daotools/set_mirror.sh | sh -s [http://860eaa91.m.daocloud.io](http://860eaa91.m.daocloud.io/)
    

    重启docker服务:

    sudo service docker restart
    

    三、下载镜像

    docker pull hyperledger/fabric-peer:x86_64-0.6.1-preview \
     && docker pull hyperledger/fabric-membersrvc:x86_64-0.6.1-preview \
     && docker pull yeasy/blockchain-explorer:latest \
     && docker tag hyperledger/fabric-peer:x86_64-0.6.1-preview hyperledger/fabric-peer \
     && docker tag hyperledger/fabric-peer:x86_64-0.6.1-preview hyperledger/fabric-baseimage \
     && docker tag hyperledger/fabric-membersrvc:x86_64-0.6.1-preview hyperledger/fabric-membersrvc
    

    图片:

    Paste_Image.png

    四、安装git

    1.安装依赖包:

    sudo yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel gcc perl-ExtUtils-MakeMaker
    

    2.下载git源码并解压安装:

    $ wget https://github.com/git/git/archive/v2.3.0.zip
    $ unzip v2.3.0.zip
    $ cd git-2.3.0
    

    3.编译安装:

    make prefix=/usr/local/git all
    sudo make prefix=/usr/local/git install
    

    4.修改环境变量:

    sudo vim /etc/profile
    然后在文件的最后一行,添加下面的内容,然后保存退出。
    export PATH=/usr/local/git/bin:$PATH
    

    5.使用source命令立即保存:

    source /etc/profile
    

    6.查看版本

        
    git version
    
    Paste_Image.png

    五、使用PBFT模式

    PBFT 是经典的分布式一致性算法,也是 hyperledger 目前最推荐的算法,该算法至少需要 4 个节点。
    1.首先,下载 Compose 模板文件。

    git clone https://github.com/yeasy/docker-compose-files
    

    2.进入 hyperledger/0.6/pbft 目录,查看包括若干模板文件

    Paste_Image.png

    节点的情况我还没弄明白,后面还要继续研究,这里我就不乱说了

    3.快速启动一个 4 个 PBFT 节点+1 个 CA 节点 + 1 个 Blockchain-explorer,并启用 CA 功能的集群:

    docker-compose -f 4-peers-with-membersrvc-explorer.yml up
    

    六、开始部署chaincode

    集群启动后,进入一个 VP 节点。以 pbft 模式为例,节点名称为 pbft_vp0_1

    docker exec -it pbft_vp0_1 bash
    
    Paste_Image.png

    部署example02

    这里要先登录,如果是安全模式的话
    账号保存在cat membersrvc/membersrvc.yaml
    这里以内部账号jim 为例子
    peer network login jim 6avZQLwcUe9b
    
    
    peer chaincode deploy -p github.com/hyperledger/fabric/examples/chaincode/go/chaincode_example02 -c '{"Function":"init", "Args": ["a","100", "b", "200"]}'
    
    Paste_Image.png

    也可以再这里查看账号

    Paste_Image.png

    记录到环境变量 CC_ID 中

    CC_ID="ee5b24a1f17c356dd5f6e37307922e39ddba12e5d2e203ed93401d7d05eb0dd194fb9070549c5dc31eb63f4e654dbd5a1d86cbb30c48e3ab1812590cd0f78539"
    

    查询 chaincode

    peer chaincode query -u lukas -n ${CC_ID} -c '{"Function": "query", "Args": ["a"]}'
    
    Paste_Image.png

    相关文章

      网友评论

          本文标题:hyperledger 区块链 环境搭建与测试

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