Configure and start a Hyperledger Fabric peer in one account that connects to a Fabric network in another account. The peer belongs to one of the organisations already present in the Fabric network.
- Your new peer will connect to the Orderer service, which orders the transactions and groups them into blocks.
- The Orderer service runs in a separate AWS Account and Region, and exposes an endpoing using an AWS Network Load Balancer (NLB)
A remote peer connects to the orderer service according to the following process:
- The orderer URL and port is written in the configtx.yaml file, and encoded into the genesis block of a channel
- Before a peer joins an existing channel, the genesis block (or channel config block) must be available, so that the peer can execute:
peer channel join -b /$DATA/$CHANNEL_NAME.block
- The peer joins the channel and receives a copy of the genesis block, which contains the orderer endpoint and the TLS cert for the orderer.
- The peer establishes a connection to the orderer based on this information
To establish this connection between a remote peer running in one AWS account and the orderer running in another AWS account, I use NLB (network load balancer) to expose the gRPC endpoints of peers and orderers.
This requires the following to be configured in order to connect a remote peer:
- AnchorPeers->Host in configtx.yaml must be an external DNS. I expose the peer using an NLB, and update this configuration variable with the NLB endpoint (see the script gen-channel-artifacts.sh)
- Profile->->Orderer->Addresses in configtx.yaml must contain an external DNS for the orderer service node endpoint. It can contain a mix of internal and external DNS entries. I run 2x orderer service nodes, expose them using NLB, and update this configuration variable with the local and NLB endpoints. The peers will loop through all the endpoints until they find one that works. This means that peers local to the orderer and remote peers will be able to connect to the orderer endpoint (see the script gen-channel-artifacts.sh)
- ORDERER_HOST in k8s/fabric-deployment-orderer1-org0.yaml must be updated with the NLB endpoint as this is used as the host URL when generating the TLS cert for the orderer, so it's important it matches the URL the orderer is listening on (i.e. the NLB endpoint) (see the script utilities.sh)
- The following ENV variables must be updated in the peer. These are updated in env.sh (if required), and also in the
k8s/fabric-deployment-peer..... yaml files (see the script utilities.sh):
- PEER_HOST
- CORE_PEER_ADDRESS
- CORE_PEER_GOSSIP_EXTERNALENDPOINT
Note that these steps are already done for you in the scripts. If [ $FABRIC_NETWORK_TYPE == "PROD" ] (see env.sh), the scripts will create an NLB for the orderer and the anchor peers, and update env.sh with the NLB DNS. These details then find their way into configtx.yaml, and therefore into mychannel.block. See configtx.yaml, which should contain something similar to this:
Profiles:
OrgsOrdererGenesis:
Orderer:
# Orderer Type: The orderer implementation to start
# Available types are "solo" and "kafka"
OrdererType: kafka
Addresses:
- a350740ea6df511e88a810af1c0a30f8-5dfb744db3223cc4.elb.us-west-2.amazonaws.com:7050
- orderer1-org0.org0:7050
You need an EKS cluster to start. The EKS cluster should be in a different account to the main EKS cluster you created in Part 1, and could also be in a different region.
The easiest way to do this is to create an EKS cluster using the eksctl tool. In the same VPC as EKS you'll also need an EFS drive (for the Fabric cryptographic material) and an EC2 bastion host, which you'll use to create and manage the Fabric network. Open the EKS Readme in this repo and follow the instructions. Once you are complete come back to this README.
These steps will join a new remote peer to a channel, and connect it to the orderer service and other anchor peers so that the ledger state can be replicated. New peers have no state (i.e. no ledger or world state) and by default do not belong to any channel. They do not have chaincode installed, which means they won't be able to take part in any TX. The scripts will take care of this by creating a new peer, joining the channel and installing chaincode.
If you are creating a brand new peer you'll need the certificate and key information for the organisation the peer belongs to. The steps below are a quick and dirty way of obtaining this info - not recommended for production use. For production use, you should create a new organisation, generate the certs and keys for the new org, add the new organisation to the channel config, then start the peers for the new org. See Part 3: for details on how to do this.
However, a quick method of setting up a remote peer for an existing org involves copying the existing crypto material. This step assumes you have setup a Kubernetes cluster in your new AWS account, with the included EFS drive, as indicated at the top of this README.
There are two ways to copy the crypto material: using 'scp' or via an S3 bucket:
- SSH into your EC2 bastion, the one you use for administering the main Kubernetes cluster in your original AWS account (i.e. the EKS cluster you created in Part 1)
- In the repo directory, in the workshop-remote-peer sub-directory, edit the script
./facilitator/copy-crypto-to-S3.sh
and update the following variables:- region - the region where you have installed EKS
- S3BucketName - a unique bucket name that will be created in your account, with public access to the crypto material
- The script
./facilitator/copy-crypto-to-S3.sh
will copy all the keys and certs from the Fabric network you created in Part 1 and store these in S3. You can then download them to your EC2 bastion and copy them to EFS.
Note that this will only work if you have the AWS CLI configured on your EC2 bastion (which you would have if you are using EKS).
If this script indicates it's unable to copy the 'tar', you can do it manually following the steps in ./facilitator/copy-crypto-to-S3.sh
- Copy the crypto material to S3:
cd
cd hyperledger-on-kubernetes/workshop-remote-peer
./facilitator/copy-crypto-to-S3.sh
- SSH into the EC2 bastion you created in the new AWS account and download the crypto information:
cd
curl https://s3-us-west-2.amazonaws.com/mcdg-blockchain-workshop/opt.tar -o opt.tar
ls -l
- SSH into your EC2 bastion, the one you use for administering the main Kubernetes cluster in your original AWS account (i.e. the EKS cluster you created in Part 1)
- In the home directory, execute
sudo tar -cvf opt.tar /opt/share/
, to zip up the mounted EFS directory with all the certs and keys - Exit the SSH, back to your local laptop or Cloud9 instance
- Copy the tar file to your local laptop or Cloud9 instance using (replace with your directory name, EC2 DNS and keypair):
scp -i /Users/edgema/Documents/apps/eks/eks-fabric-key.pem ec2-user@ec2-18-236-169-96.us-west-2.compute.amazonaws.com:/home/ec2-user/opt.tar opt.tar
- Copy the local tar file to the EC2 bastion in your new AWS account using (replace with your directory name, EC2 DNS and keypair):
scp -i /Users/edgema/Documents/apps/eks/eks-fabric-key-account1.pem /Users/edgema/Documents/apps/hyperledger-on-kubernetes/opt.tar ec2-user@ec2-34-228-23-44.compute-1.amazonaws.com:/home/ec2-user/opt.tar
- SSH into the EC2 bastion you created in the new AWS account
- Extract the crypto material (you may need to use 'sudo'. Ignore the 'permission denied' error message, if you receive one):
cd /
rm -rf /opt/share
tar xvf ~/opt.tar
ls -lR /opt/share
- List the crypto material in EFS. You should see something like this (though this is only a subset):
$ ls -lR /opt/share
/opt/share:
total 36
drwxrwxr-x 3 ec2-user ec2-user 6144 Jul 17 03:54 ica-org0
drwxrwxr-x 3 ec2-user ec2-user 6144 Jul 17 04:53 ica-org1
drwxrwxr-x 3 ec2-user ec2-user 6144 Jul 17 03:54 ica-org2
drwxrwxr-x 2 ec2-user ec2-user 6144 Jul 17 03:32 orderer
drwxrwxr-x 7 ec2-user ec2-user 6144 Jul 19 13:23 rca-data
drwxrwxr-x 3 ec2-user ec2-user 6144 Jul 17 03:34 rca-org0
drwxrwxr-x 3 ec2-user ec2-user 6144 Jul 17 03:34 rca-org1
drwxrwxr-x 3 ec2-user ec2-user 6144 Jul 17 03:34 rca-org2
drwxrwxr-x 2 ec2-user ec2-user 6144 Jul 19 12:45 rca-scripts
/opt/share/ica-org0:
total 124
-rw-r--r-- 1 root root 822 Jul 17 03:34 ca-cert.pem
-rw-r--r-- 1 root root 1600 Jul 17 03:34 ca-chain.pem
-rw-r--r-- 1 root root 15944 Jul 17 03:34 fabric-ca-server-config.yaml
-rw-r--r-- 1 root root 94208 Jul 17 03:54 fabric-ca-server.db
drwxr-xr-x 5 root root 6144 Jul 17 03:34 msp
-rw-r--r-- 1 root root 912 Jul 17 03:34 tls-cert.pem
.
.
.
A couple of configuration steps are required before starting the new peer:
- SSH into the EC2 bastion you created in the new AWS account
- Navigate to the
hyperledger-on-kubernetes
repo - Edit the file
remote-peer/scripts/env-remote-peer.sh
. Update the following fields:- Set PEER_ORGS to one of the organisations in the Fabric network. Example: PEER_ORGS="org1"
- Set PEER_DOMAINS to one of the domains in the Fabric network. Example: PEER_DOMAINS="org1"
- Set PEER_PREFIX to any name you choose. This will become the name of your peer on the network. Try to make this unique within the network. Example: PEER_PREFIX="michaelpeer"
- Make sure the other properties in this file match your /scripts/env.sh
We are now ready to start the new peer. On the EC2 instance in the new account created above, in the repo directory, run:
cd
cd hyperledger-on-kubernetes
./remote-peer/start-remote-peer.sh
This will do the following:
- Create a merged copy of env.sh on the EFS drive (i.e. in /opt/share/rca-scripts), which includes the selections you made above (e.g. PEER_PREFIX)
- Generate a kubernetes deployment YAML for the remote peer
- Start a local certificate authority (CA). You'll need this to generate a new user for your peer
- Register your new peer with the CA
- Start the new peer
- Run the test cases
The peer will start, and the test case script will join it to the default channel. To confirm that your peer is working you can check the following logs:
- test-fabric-marbles pod. You may see some errors in this log file as the peer tries to create a channel that already exists, or create a marble that already exists, but it should successfully query and transfer marbles.
- michaelpeer1-org1 pod. Use the statement below, replacing the peer name with your own. This will show you the blocks that are replicating from the Fabric network to your new peer. You may also see gossip related warnings here informing you that the peer cannot connect to other peers. Ignore these - the peer is trying to connect to the local peers running in the Part 1 orderer, but only the anchor peers in the orderer network expose an external IP (via an NLB). 'peer2' in the orderer org does not expose an external IP, hence the warnings.
kubectl logs michaelpeer1-org1-ff9b759d8-gkjn2 -n org1 -c michaelpeer1-org1 | grep block
Look for messages in the log file such as Channel [mychannel]: Committing block [14] to storage
.