1.智能合约

  • 执行环境:以太坊虚拟智能合约执行环境EVM,fabric执行环境是docker

  • 链码

    • 是应用层和区块链底层的中间点
    • 每一个链码执行环境是一个独立的docker
    • 使用GRPC协议与背书节点通信,只有背书节点才能运行智能合约
  • 链码的生命周期

    • 打包:智能合约的编写和编译
    • 安装:将打包好的文件,上传到背书节点
    • 实例化:实际安装,执行Init方法,只执行一次,构造函数
    • 升级:升级和修复链码
    • 交互:自己定义的方法的调用
  • 链码的交互流程

  • 系统链码(CC:chaincode)

    • LSCC:管理链码的生命周期
    • CSCC:配置管理链码,管理链的配置
    • QSCC:查询账本存储,是一个区块索引的外部服务
    • ESCC:交易背书的链码,交易执行后的链码进行封装签名,给客户端返回背书交易结果
    • VSCC:交易验证的链码
  • 链码编程的接口

    • Init():链码初始化,只执行一次
    • Invoke() :链码的业务逻辑的编写
    • 上面2个方法参数一样,参数是SDK的接口
  • 链码SDK的接口

    • 写代码再看
  • 一些注意点

    • 分布式多机多节点执行,链码会执行多次
    • 不写随机函数,交易会无效,多次执行不一样
    • 不写系统时间,多机时间不一定一样

2.网络搭建配置的实现

  • crypto-config.yaml:用于配置节点的个数,参考firstnetwork编写
  • 编写好后,传到linux对应目录
  • 进入deploy目录,设置工作目录为当前目录
    export FABRIC_CFG_PATH=$GOPATH/src/fabric_asset/deploy
  • 指定按照yaml文件生成配置
    cryptogen generate --config=./crypto-config.yaml

  • configtx.yaml:用于区块联盟中的组织信息,配置名字和证书等的位置,参考firstnetwork编写

  • 编写好后,传到linux对应目录

  • 创建用于存放配置的目录
    mkdir config

  • 生成系统链的创世区块
    -profile:指定联盟配置
    -outputBlock:指定存放的位置
    configtxgen -profile OneOrgsOrdererGenesis -outputBlock ./config/genesis.block

  • 生成通道的创世交易
    -profile:指定业务联盟
    -outputCreateChannelTx:指定存放路径
    -channelID:指定创建名字
    configtxgen -profile TwoOrgsChannel -outputCreateChannelTx ./config/mychannel.tx -channelID mychannel

  • 生成两个组织锚节点的交易信息
    configtxgen -profile TwoOrgsChannel -outputAnchorPeersUpdate ./config/Org0MSPanchors.tx -channelID mychannel -asOrg Org0MSP
    configtxgen -profile TwoOrgsChannel -outputAnchorPeersUpdate ./config/Org1MSPanchors.tx -channelID mychannel -asOrg Org1MSP


  • 新建docker-compose.yaml文件并移动到deploy目录下

3.启动网络

  • 启动docker,后台运行(要以管理员身份运行)
    docker-compose up -d

  • 查看orderer节点的运行日志
    docker logs orderer.example.com

  • 与客户端交互操作
    docker exec -it cli bash

  • 创建通道
    -o:指定与哪个orderer节点通信
    -c:指定创建的通道名称
    -f:指定使用的文件
    peer channel create -o orderer.example.com:7050 -c mychannel -f /etc/hyperledger/config/mychannel.tx

  • 加入通道
    peer channel join -b mychannel.block

  • 查看peer加入的通道列表
    peer channel list

  • 指定主节点
    peer channel update -o orderer.example.com:7050 -c mychannel -f /etc/hyperledger/config/Org1MSPanchors.tx


  • 安装链码
    -n:安装的名字
    -v: version
    -l:使用语言
    -p:path
    peer chaincode install -n badexample -v 1.0.0 -l golang -p github.com/chaincode/badexample
  • 克隆一个会话,交互执行peer0,查看安装的链码
    docker exec -it peer0.org1.example.com bash
    cd /var/hyperledger/production/chaincodes/
  • 链码实例化
    peer chaincode instantiate -o orderer.example.com:7050 -C mychannel -n badexample -l golang -v 1.0.0 -c '{"Args":["init"]}'
  • 链码交互执行
    peer chaincode query -C mychannel -n badexample -c '{"Args":[]}'
  • 多次执行查询,得到的结果不同,因为invoke()中使用了随机数,不要这么做

4.网络关闭

  • 退出客户端
    exit
  • 在deploy目录下关闭docker
    docker-compose down