Setting up your development environment for Hyperledger Fabric
Get a peek into how a professional Hyperledger Fabric dev environment looks like. We take you from the directory structure to custom scripts we’ve written to automate testing.
Subscribe to our awesome Newsletter.
The Directory Structure
Having a clean directory structure enables Fabric programmers to instinctively know where each file should sit. Here is our approach to organising the Fabric dev environment.
Where should the Chaincode go?
A lot of developers, mount the chaincode directly from the development folder - that’s a terrible idea.
What you should do is develop chaincode in your GOPATH under the vendor-name github.com/yourproject/and-here-goes-your-chaincode-files
. You can also write a script which will copy your chaincode under GOPATH and run a go build command to spit out the go-errors before running it in your Fabric tools. This will reduce your development to production time.
Here’s a simple script to copy your chaincode,
1 2 3 4 5 6 7 | #!/bin/bash echo "Copying your chaincode to the place where it belongs." rm -rf $GOPATH/src/github.com/project-name/go & mkdir -p $GOPATH/src/github.com/project-name/go cp -Rf chaincode/\* $GOPATH/src/github.com/project-name/go/ |
If you want to build the code, just add this,
1 2 3 4 5 6 7 8 9 | #!/bin/bash echo "Stepping into the chaincode's directory" cd $GOPATH/src/github.com/acmebc/go/ echo "Building your chaincode. Tada." go build . |
This will build once when you finish your chaincode development. It will deal with all the ‘unused-variables’, ‘scope-problems’ and any other Go warnings.
Starting Your Network
Let’s assume that your Fabric network is up and running. Ok? What if you didn’t have a network running? Yeah. I can understand.
I am keeping this article as simple as possible. So, follow these steps as of now. The deep philosophies behind every single step will be explained later.
1
| git clone https://github.com/hyperledger/fabric-samples |
If you don’t have Fabric installed in your environment,
1 2 | cd fabric-samples/scripts ./fabric-preload.sh |
Then proceed with this,
1 2 | cd fabric-samples/basic-network vi docker-compose.yml |
Under CLI services, see the volumes mounted. You can see that the chaincode is mounted with a relative folder. Let’s change it,
|
|
If you see at Line 18, it has been changed with respect to GOPATH. 😄
Now let’s start our docker-compose i.e, our network with our chaincode mounted to it.
Let’s do it in our style. Create a bash file named start-network.sh,
1 2 3 4 5 | #!/bin/bash # start-network.sh cd basic-network ./start.sh |
Now the fabric-network is up and running. You can check it by typing docker ps in console.
Installing the Chaincode
Now our time to launch our armageddon. So we have our network running. Lets install the chaincode using the bash script we wrote,
1 2 3 4 5 6 7 8 9 10 | #!/bin/bash # install-chaincode.sh LANGUAGE=golang CC_SRC_PATH=github.com/acmebc/go CC_VERSION=1.0 docker exec -e "CORE_PEER_LOCALMSPID=Org1MSP" -e "CORE_PEER_MSPCONFIGPATH=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org1.example.com/users/[email protected]/msp" cli peer chaincode install -n acmebc -v $CC_VERSION -p "$CC_SRC_PATH" -l "$LANGUAGE" docker exec -e "CORE_PEER_LOCALMSPID=Org1MSP" -e "CORE_PEER_MSPCONFIGPATH=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org1.example.com/users/[email protected]/msp" cli peer chaincode instantiate -o orderer.example.com:7050 -C mychannel -n acmebc -l "$LANGUAGE" -v $CC_VERSION -c '{"Args":\\\[""\\\]}' -P "OR ('Org1MSP.member')" |
That’s all! You might be wondering, why do we need to write a bash script for every small process? Answer to that question: You can write a single bash master script to control everything with logical-conditions.
Now that we have our chaincode installed. You can try the query/invoke commands and check how it’s working. Or you can ping the application that you integrated with the network.
Updating the Chaincode
This is where developers waste time. Updating the code, building it and deploying it again by updating the chaincode-version. Doing it in our style, let’s write a script.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | #!/bin/bash LANGUAGE=golang CC_SRC_PATH=github.com/acmebc/go CC_VERSION=1.0 TEMP_CC_VERSION+=$(date +".%I.%M.%S") # Appending with temporary timestamp. # Replace the chaincode with our new updated code. rm -rf $GOPATH/src/github.com/project-name/go & mkdir -p $GOPATH/src/github.com/project-name/go cp -Rf chaincode/\\\* $GOPATH/src/github.com/project-name/go/ # Building the go chaincode cd $GOPATH/src/github.com/project-name/go/ go build . # Run the update action docker exec -e "CORE_PEER_LOCALMSPID=Org1MSP" -e "CORE_PEER_MSPCONFIGPATH=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org1.example.com/users/[email protected]/msp" cli peer chaincode install -n acmebc -v $TEMP_CC_VERSION -p "$CC_SRC_PATH" -l "$LANGUAGE" docker exec -e "CORE_PEER_LOCALMSPID=Org1MSP" -e "CORE_PEER_MSPCONFIGPATH=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org1.example.com/users/[email protected]/msp" cli peer chaincode upgrade -o orderer.example.com:7050 -C mychannel -n acmebc -l "$LANGUAGE" -v $TEMP_CC_VERSION -c '{"Args":\\\["init"\\\]}' -P "OR ('Org1MSP.member')" |
That’s it. Updated, yo! Run your queries and see the magic.
Click here to learn more about Hyperleger and Blockchain straight from our developers.