The scripts in this section will launch an AKS cluster, setup Azure Files for persistence, and configure a bastion
host that you can login and start a Hyperledger Fabric network. The configuration file env.sh specifies the number and type of Azure VM instances and type of storage used by the AKS cluster, e.g., 3 VM instances are used by the default configuration.
Install Azure CLI as described by the link.
Once your Azure account is setup, you can login by typing the command:
az login
Enter your account info in a pop-up browser window. Note that you may lookup your account details by using the Azure Portal, although it is not absolutely necessary since we use only Azure CLI
scripts.
Create and start the AKS cluster with all defaults:
cd ./az
./az-util.sh create
This script accepts 2 parameters for you to specify a different Azure environment, e.g.,
./az-util.sh create -n fab -r westus2
would create an AKS cluster with name prefix of fab
, at the Azure location of westus2
.
Wait 10 minutes for the cluster nodes to startup. When the cluster is up, it will print a line, such as:
You can use this command to login to the bastion
VM instance and create a Hyperledger Fabric network in the AKS cluster. Note that the ssh
keypair for accessing the bastion
host is in your $HOME/.ssh
folder, and named as id_rsa.pub
and id_rsa
. The script will generate a new keypair if these files do not exist already.
Note also that the scripts have set the security group such that the bastion
host can be accessed by only your workstation's current IP address. If your IP address changes, you'll need to login to Azure to update the security rule, or simply re-run the script:
cd ./az
az login
./create-bastion.sh fab westus2
Log on to the bastion
host, e.g., (your real host IP will be different):
After login, you'll notice that everything is automatically setup for you. You may verify the following configurations.
df
command should show that anAzure File
storage is already mounted at/mnt/share
;kubectl get pod,svc --all-namespaces
should show you the Kubernetes system services and PODs;ls ~
should show you that the latest code of this project is already downloaded at$HOME/fabric-operation
.
Following steps will start and smoke test the default Hyperledger Fabric network with 2 peers, and 3 orderers using etcd raft
consensus. You can learn more details about these commands here.
cd ./fabric-operation/namespace
./k8s-namespace.sh create
This command creates a namespace for the default Fabric operator company, netop1
, and sets it as the default namespace. It also creates Kubernetes secret for accessing Azure Files storage for persistence. The option -t az
specifies the working environment for Azure
, and it is optional since the script will automatically detect the environment if it is not specified. You can verify this step using the following commands:
kubectl get namespaces
should show a list of namespaces, including the new namespacenetop1
;kubectl get secret
should show that a secret namedazure-secret
is created;kubectl config current-context
should show that the default namespace is set tonetop1
.
cd ../ca
./ca-server.sh start
# wait until 3 ca server and client PODs are in running state
./ca-crypto.sh bootstrap
This command starts 2 CA servers and a CA client, and generates crypto data according to the network specification, netop1.env. You can verify the result using the following commands:
kubectl get pods
should list 3 running PODs:ca-server
,tlsca-server
, andca-client
;ls /mnt/share/netop1.com/
should list folders containing crypto data, i.e.,canet
,cli
,crypto
,gateway
,namespace
,orderers
,peers
, andtool
.
cd ../msp
./msp-util.sh start
# wait until the tool POD is in running state
./msp-util.sh bootstrap
This command starts a Kubernetes POD to generate the genesis block and transaction for creating a test channel mychannel
based on the network specification. You can verify the result using the following commands:
kubectl get pods
should list a running PODtool
;ls /mnt/share/netop1.com/tool
should show the generated artifacts:etcdraft-genesis.block
,mychannel.tx
,mychannel-anchors.tx
, andconfigtx.yaml
.
cd ../network
./network.sh start
This command starts the orderers and peers using the crypto and genesis block created in the previous steps. You can verify the network status using the following commands:
kubectl get pods
should list 3 running orderers and 2 running peers;kubectl logs orderer-2
should show that a raft leader is elected by all 3 orderer nodes;kubectl logs peer-1 -c peer
should show the logs ofpeer-1
, that shows its successfully completed gossip communications withpeer-0
.ls /mnt/share/netop1.com/orderers/orderer-0/data
shows persistent storage of theorderer-0
, similar to other orderer nodes;ls /mnt/share/netop1.com/peers/peer-0/data
shows persistent storage of thepeer-0
, similar to other peer nodes.
cd ../network
./network.sh test
This command creates the test channel mychannel
, installs and instantiates a test chaincode, and then executes a transaction and a query to verify the working network. You can verify the result as follows:
- The last result printed out by the test should be
90
; - Orderer data folder, e.g.,
/mnt/share/netop1.com/orderers/orderer-0/data
would show a block file added under the chain of a new channelchains/mychannel
; - Peer data folder, e.g.,
/mnt/share/netop1.com/peers/peer-0/data
would show a new chaincodemycc.1.0
added to thechaincodes
folder, and a transaction block file created underledgersData/chains/chains/mychannel
.
Refer gateway for more details on how to build and start a REST API service for applications to interact with one or more Fabric networks. The following commands can be used on the bastion host to start a gateway service that exposes a Swagger-UI.
cd ../service
# build the gateway service from source code, which creates executable 'gateway-linux'
make dist
# config and start gateway service for Azure
./gateway.sh start
The last command started 2 PODs to run the gateway service, and created a load-balancer service with a publicly accessible port. The load-balancer port is automatically open to public, which is convenient for dev and test, although Azure recommends to add Ingress controllers
for production use.
The URL of the load-balancer is printed by the script as, e.g.,
http://52.148.162.197:7081/swagger
Copy and paste the URL (your actual URL will be different) into a Chrome web-browser, and use it to test the sample chaincode as described in gateway.
Refer dovetail for more details about Project Dovetail, which is a visual programming tool for modeling Hyperledger Fabric chaincode and client apps.
A Dovetail chaincode model, e.g., marble.json is a JSON file that implements a sample chaincode by using the TIBCO Flogo visual modeler. Use the following script to build and instantiate the chaincode.
# create chaincode package
cd ${HOME}/fabric-operation/msp
./msp-util.sh build-cds -m ../dovetail/samples/marble/marble.json
# install and instantiate chaincode
cd ../network
./network.sh install-chaincode -n peer-0 -f marble_cc_1.0.cds
./network.sh install-chaincode -n peer-1 -f marble_cc_1.0.cds
./network.sh instantiate-chaincode -n peer-0 -c mychannel -s marble_cc -v 1.0 -m '{"Args":["init"]}'
You can send test transactions by using the Swagger UI of the gateway service, e.g., insert a new marble by posting the following transaction:
{
"connection_id": "16453564131388984820",
"type": "INVOKE",
"chaincode_id": "marble_cc",
"transaction": "initMarble",
"parameter": [
"marble1","blue","35","tom"
]
}
By using the same Flogo
modeling UI, we can also implement a client app, e.g., marble_client.json, that updates or queries the Fabric distributed ledger by using the marble
chaincode. Use the following script to build and run a client app as a Kubernetes service.
# generate network config if skipped the previous gateway test
cd ${HOME}/fabric-operation/service
./gateway.sh config
# build and start client using the generated network config
cd ../dovetail
./dovetail.sh config-app -m samples/marble_client/marble_client.json
./dovetail.sh start-app -m marble_client.json
The above command will start 2 instances of the marble-client
and expose a load-balancer
end-point for other applications to invoke the service. Once the script completes successfully, it will print out the service end-point as, e.g.,
access marble-client servcice at http://40.91.88.121:7091
You can use this end-point to update or query the blockchain ledger. marble.postman_collection.json contains a set of REST messages that you can import to Postman and invoke the marble-client
REST APIs.
Stop the client app after tests complete:
./dovetail.sh stop-app -m marble_client.json
cd ../network
./network.sh shutdown -d
This command shuts down orderers and peers, and the last argument -d
means to delete all persistent data as well. If you do not use the argument -d
, it would keep the test ledger file in the Azure Files
storage, and so it can be loaded when the network restarts. You can verify the result using the following command.
kubectl get svc,pod
should not list any running orderers or peers;- The orderers and peers' persistent data folder, e.g.,
/mnt/share/netop1.com/peers/peer-0/data
would be deleted if the option-d
is used.
You can exit from the bastion
host, and clean up every thing created in Azure when they are no longer used, i.e.,
cd ./az
./az-util.sh cleanup -n fab -r westus2
This will clean up the AKS cluster and the Azure Files storage created in the previous steps. Make sure that you supply the same parameters as that of the previous az-util.sh create
command if they are different from the default values.
If your local workstation has kubctl
installed, and you want to execute kubectl
commands directly from the localhost, instead of going through the bastion
host, you can set the env,
export KUBECONFIG=/path/to/fabric-operation/az/config/config-fab.yaml
where the /path/to
is the location of this project on your localhost, and config-fab.yaml
is named after the ENV_NAME
specified in env.sh
. The file is created for you when you execute az-util.sh create
, and it is valid only while the AKS cluster is running.
You can then use kubectl
commands against the Azure AKS cluster from your localhost directly, e.g.,
kubectl get pod,svc --all-namespaces
The containers created by the scripts will use the name of a specified operating company, e.g., netop1
, as the Kubernetes namespace. To save you from repeatedly typing the namespace in kubectl
commands, you can set netop1
as the default namespace by using the following commands:
kubectl config view
kubectl config set-context netop1 --namespace=netop1 --cluster=fabAKSCluster --user=clusterUser_fabRG_fabAKSCluster
kubectl config use-context netop1
Note to replace the values of cluster
and user
in the second command by the corresponding output from the first command. This configuration is automatically done on the bastion host when the k8s-namespace.sh create
script is called.