Hyperledger

본문 바로가기
사이트 내 전체검색


Hyperledger
Hyperledger

2. 체인코드 수정하기

페이지 정보

작성자 관리자 댓글 0건 조회 2,505회 작성일 19-11-14 12:18

본문

2. 체인코드 수정하기

터미널1. docker 이미지 재시작

​[Ctrl+C]를 클릭하여 종료한다.

peer         | 2019-03-20 09:33:40.640 UTC [msp.identity] Sign -> DEBU dc9c Sign: digest: D18B553283AFC791A71A1AB3F379E85F4599DAAE3CE5B43F6A912E5BFD23E73D
^CGracefully stopping... (press Ctrl+C again to force)
Stopping chaincode ... done
Stopping cli       ... done
Stopping peer      ... done
Stopping orderer   ... done
root@leelab:~/hyperledger/fabric-samples/chaincode-docker-devmode# docker-compose -f docker-compose-simple.yaml down
Removing chaincode ... done
Removing cli       ... done
Removing peer      ... done
Removing orderer   ... done
Removing network chaincodedockerdevmode_default
root@leelab:~/hyperledger/fabric-samples/chaincode-docker-devmode#

root@leelab:~/hyperledger/fabric-samples/chaincode-docker-devmode# docker-compose -f docker-compose-simple.yaml up

터미널3. 체인코드 수정

 

docker 이미지에서 빠져나온다.

root@38811b1c6e63:/opt/gopath/src/chaincodedev# exit
exit
root@client:~/hyperledger/fabric-samples/chaincode-docker-devmode# cd ../chaincode/chaincode_example02/go
root@client:~/hyperledger/fabric-samples/chaincode/chaincode_example02/go# 

root@client:~/hyperledger/fabric-samples/chaincode/chaincode_example02/go# vi chaincode_example02.go

 

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 == "reg" {
                // reg
                return t.reg(stub, args)
        }

        return shim.Error("Invalid invoke function name. Expecting \"invoke\" \"delete\" \"query\"")
}
// reg
func (t *SimpleChaincode) reg(stub shim.ChaincodeStubInterface, args []string) pb.Response {
    var A string    // Entities
    var Aval int // Asset holdings
    var err error

    if len(args) != 2 {
        return shim.Error("Incorrect number of arguments. Expecting 2")
    }

    A = args[0]

    Aval, err = strconv.Atoi(args[1])
    if err != nil {
        return shim.Error("Expecting integer value for asset holding")
    }

    fmt.Printf("New value = %d\n", Aval)


    // Write the state back to the ledger
    err = stub.PutState(A, []byte(strconv.Itoa(Aval)))
    if err != nil {
        return shim.Error(err.Error())
    }

    return shim.Success(nil)
} 

 

터미널2. 체인코드 빌드 및 시작

현재 실행된 체인코드를 중지한다. (Ctrl+C)키를 누른다.

​ex02 Init
Aval = 100, Bval = 200
ex02 Invoke
Aval = 90, Bval = 210
ex02 Invoke
Query Response:{"Name":"a","Amount":"90"}
^C
root@415af2cc7fec:/opt/gopath/src/chaincode# cd chaincode_example02/go
root@415af2cc7fec:/opt/gopath/src/chaincode/chaincode_example02/go# go build -o chaincode_example02

 

root@ccd6d17781d6:/opt/gopath/src/chaincode/chaincode_example02/go# CORE_PEER_ADDRESS=peer:7052 CORE_CHAINCODE_ID_NAME=mycc:0 ./chaincode_example02
2019-11-14 02:50:53.890 UTC [shim] setupChaincodeLogging -> INFO 001 Chaincode log level not provided; defaulting to: INFO
2019-11-14 02:50:53.894 UTC [shim] setupChaincodeLogging -> INFO 002 Chaincode (build level: ) starting up ...
2019-11-14 02:50:53.895 UTC [bccsp] initBCCSP -> DEBU 001 Initialize BCCSP [SW]
2019-11-14 02:50:53.895 UTC [grpc] DialContext -> DEBU 002 parsed scheme: ""
2019-11-14 02:50:53.895 UTC [grpc] DialContext -> DEBU 003 scheme "" not registered, fallback to default scheme
2019-11-14 02:50:53.896 UTC [grpc] watcher -> DEBU 004 ccResolverWrapper: sending new addresses to cc: [{peer:7052 0  <nil>}]
2019-11-14 02:50:53.896 UTC [grpc] switchBalancer -> DEBU 005 ClientConn switching balancer to "pick_first"
2019-11-14 02:50:53.896 UTC [grpc] HandleSubConnStateChange -> DEBU 006 pickfirstBalancer: HandleSubConnStateChange: 0xc00035a2a0, CONNECTING
2019-11-14 02:50:53.935 UTC [grpc] HandleSubConnStateChange -> DEBU 007 pickfirstBalancer: HandleSubConnStateChange: 0xc00035a2a0, READY

 

터미널3. chaincode 사용

 

[root@leelab chaincode-docker-devmode]# docker exec -it cli bash
root@f75979e099b9:/opt/gopath/src/chaincodedev#

 


# peer chaincode install -p chaincodedev/chaincode/chaincode_example02/go -n mycc -v 0
# peer chaincode instantiate -n mycc -v 0 -c '{"Args":["init","a","100","b","200"]}' -C myc

 


초기값 a=100, b=200

 


# peer chaincode invoke -n mycc -c '{"Args":["reg","c","1000"]}' -C myc

 


2019-03-20 12:42:17.753 UTC [chaincodeCmd] chaincodeInvokeOrQuery -> INFO 0a7 Chaincode invoke successful. result: status:200
root@7183c9147d90:/opt/gopath/src/chaincodedev#

 

 

 


터미널2의 로그를 확인한다. 

 

ex02 Init
Aval = 100, Bval = 200
ex02 Invoke
New value = 1000 

 

댓글목록

등록된 댓글이 없습니다.


개인정보취급방침 서비스이용약관 모바일 버전으로 보기 상단으로

TEL. 063-469-4551 FAX. 063-469-4560 전북 군산시 대학로 558
군산대학교 컴퓨터정보공학과

Copyright © www.leelab.co.kr. All rights reserved.