zoukankan      html  css  js  c++  java
  • hyperledger fabric 1.0.5 分布式部署 (三)

    本篇博客主要是向读者介绍 fabric 在部署时的一些细节,还有作者自己学习过程中的心得。

    • 初始化相关密钥的程序,实际上是一个shell脚本,并且结构特别简单 

     generateArtifacts.sh 脚本里面主要执行了三个函数

    generateCerts                       # 这个是初始化组织证书和密钥的操作
    replacePrivateKey                   # 这个函数是生成一个docker-compose 脚本,没有啥用
    generateChannelArtifacts            # 这个是定义组织机构和初始化创世块的操作
    • docker-compose 启动相关容器后,执行的script.sh 脚本
    1.  首先该script.sh 脚本是通过挂载的方式传入cli 容器中的,不需要用户在宿主机器上修改后上传。
    2. script.sh 脚本实际上是创建 channel 和将 peers 加入到 channel 中,并且给 peer 安装 chaincode (智能合约),然后就是给集群初始化账户和数值,还有校验测试
    3. 虽然使用 docker-compose 启动了 4个 peers, 实际上只有三个 peer 安装了 chaincode
    4. 安装的 chaincode 源码在/opt/gopath/src/github.com/hyperledger/fabric/examples/chaincode/go/chaincode_example02/chaincode_example02.go,使用go 语言编写,用户可以随意修改,但是之后要再给peer安装,在安装时,fabric 会自动编译该go 脚本 

    给chaincode_example02.go chaincode 增加一个test 的功能,打开对应的文件,将Invoke 函数进行修改,修改后的内容

    func (t *SimpleChaincode) Invoke(stub shim.ChaincodeStubInterface) pb.Response {
            fmt.Println("ex02 Invoke")
            function, args := stub.GetFunctionAndParameters()
            if function == "invoke" {
                    // Make payment of X units from A to B
                    return t.invoke(stub, args)
            } else if function == "delete" {
                    // Deletes an entity from its state
                    return t.delete(stub, args)
            } else if function == "query" {
                    // the old "Query" is now implemtned in invoke
                    return t.query(stub, args)
            } else if function == "test" {
                    return t.test (stub, args)
            }
    
            return shim.Error("Invalid invoke function name. Expecting "invoke" "delete" "query"")
    }

    增加了一个test 的方法,test 函数代码

    func (t *SimpleChaincode) test (stub shim.ChaincodeStubInterface, args []string) pb.Response {
           var V string
           var Vval, Rval int
           var err error
    
           if len(args) != 2 {
              return shim.Error("Incorrect number of arguments. Expecting 2")
           }
    
           V = args[0]
    
           Rval, err = strconv.Atoi(args[1])
    
           if err != nil {
              return shim.Error("Expecting integer value for asset holding")
           }
    
           if Rval == 123 {
              Vvalbytes, err := stub.GetState(V)
              if err != nil {
                      return shim.Error("Failed to get state")
              }
              if Vvalbytes == nil {
                      return shim.Error("Entity not found")
              }
    
              Vval, _ = strconv.Atoi(string(Vvalbytes))
              Vval = Vval + 10
    
    
              // Write the state back to the ledger
              err = stub.PutState(V, []byte(strconv.Itoa(Vval)))
              if err != nil {
                      return shim.Error(err.Error())
              }
           }
           return shim.Success(nil)
    }

    读者给peer 重新安装chaincode 后,可以在cli 中执行以下命令,实现给对应的用户增加10 块钱 

    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":["test","a","123"]}'
    •  直接在宿主机器上执行 cli 的命令

    例如:在cli 容器上查询a 账户的余额

    docker exec -it cli peer chaincode query -C mychannel -n mycc -c '{"Args":["query","a"]}'

     用户也可以利用 docker-compose 来执行该方法,但是需要先准备docker-compose 的cli配置文件,用户可以模仿 docker-compose-cli.yaml 文件进行编写,例如作者编写了一个名字叫“docker-compose-test.yaml”的配置文件。

    这种方式有一个好处,就是执行的宿主机器,不需要知道之前是否已经启动了相关的docker 服务,因为执行docker-compose 命令时 ,会临时启动相应的docker 服务,执行完对应的shell 命令后,又会自动将其删除,真正的做到即用即起的效果。

    # Copyright IBM Corp. All Rights Reserved.
    #
    # SPDX-License-Identifier: Apache-2.0
    #
    
    version: '2'
    
    services:
    
    
      cli:
        container_name: cli
        image: hyperledger/fabric-tools
        tty: true
        environment:
          - GOPATH=/opt/gopath
          - CORE_VM_ENDPOINT=unix:///host/var/run/docker.sock
          - CORE_LOGGING_LEVEL=DEBUG
          - CORE_PEER_ID=cli
          - CORE_PEER_ADDRESS=peer0.org1.example.com:7051
          - CORE_PEER_LOCALMSPID=Org1MSP
          - CORE_PEER_TLS_ENABLED=true
          - CORE_PEER_TLS_CERT_FILE=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/server.crt
          - CORE_PEER_TLS_KEY_FILE=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/server.key
          - CORE_PEER_TLS_ROOTCERT_FILE=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/ca.crt
          - CORE_PEER_MSPCONFIGPATH=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org1.example.com/users/Admin@org1.example.com/msp
        working_dir: /opt/gopath/src/github.com/hyperledger/fabric/peer
    #    command: /bin/bash -c './scripts/script.sh ${CHANNEL_NAME}; sleep $TIMEOUT'
        volumes:
            - /var/run/:/host/var/run/
            - ../chaincode/go/:/opt/gopath/src/github.com/hyperledger/fabric/examples/chaincode/go
            - ./crypto-config:/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/
            - ./scripts:/opt/gopath/src/github.com/hyperledger/fabric/peer/scripts/
            - ./channel-artifacts:/opt/gopath/src/github.com/hyperledger/fabric/peer/channel-artifacts

    还是以查询a账号余额为例

    docker-compose -f docker-compose-test.yaml run --rm --no-deps cli peer chaincode query -C mychannel -n mycc -c '{"Args":["query","a"]}'
  • 相关阅读:
    svn 提交时强制注释、不允许指定的文件类型的钩子写法
    开源跨平台网络库(lxnet)
    关于android studio的配置记录
    一般处理程序(ashx)对session处理摘要
    利用反射代替switch -转
    c#+jquery.autocomplete.js
    C#+ajaxupload实现图片上传
    几种常见SQL分页方式效率比较-转
    js页面跳转
    C#编码规范-转
  • 原文地址:https://www.cnblogs.com/chenfool/p/8397384.html
Copyright © 2011-2022 走看看