An Ansible playbook for building a Hyperledger Fabric network with two organizations, Org1
and Org2
. Each organization has two peers. The two peers are configured with a single channel, channel1
. The FabCar sample contract is instantiated on this channel, with an endorsement policy stating that both organizations must endorse any transactions.
To run this Ansible playbook, follow these steps:
-
Ensure that you have all of the pre-requisites installed: https://github.com/IBM-Blockchain/ansible-role-blockchain-platform-manager#requirements
-
Install all required roles, including the
ibm.blockchain_platform_manager
role, from Ansible Galaxy:ansible-galaxy install -r requirements.yml --force
-
This Ansible playbook defaults to deploying to Docker. To configure the Ansible playbook to deploy to the IBM Blockchain Platform on IBM Cloud, follow these steps:
-
Edit the playbook such that the
infrastructure.type
variable is set tosaas
:infrastructure: type: saas saas: "{{ lookup('file', 'service-creds.json') | from_json }}"
-
Create a file named
service-creds.json
that contains valid service credentials for an IBM Blockchain Platform service instance on IBM Cloud. These service credentials should be of the format:{ "api_endpoint": "https://xxxxxx-optools.uss02.blockchain.cloud.ibm.com", "apikey": "xxxxxx", "configtxlator": "https://xxxxxx-configtxlator.uss02.blockchain.cloud.ibm.com", "iam_apikey_description": "Auto-generated for key xxxxxx", "iam_apikey_name": "xxxxxx", "iam_role_crn": "crn:v1:bluemix:public:iam::::serviceRole:Manager", "iam_serviceid_crn": "crn:v1:bluemix:public:iam-identity::a/xxxxxx::serviceid:ServiceId-xxxxxx" }
-
-
Run the Ansible playbook:
ansible-playbook playbook.yml
-
Information on the available nodes (peers, orderers, and certificate authorities) will be created under the
nodes
subdirectory.-
If you wish to use this network for development purposes, you can import these JSON files into a Fabric Environment using the IBM Blockchain Platform extension for Visual Studio Code.
For more information on this task, follow the process to create a new Fabric Environment documented here: https://github.com/IBM-Blockchain/blockchain-vscode-extension#connecting-to-another-instance-of-hyperledger-fabric
-
If you are using the IBM Blockchain Platform on IBM Cloud, you do not need to import these JSON files. All of the nodes will already be present in your web console.
-
-
The
wallets
subdirectory will contain all of the identities (certificates and private keys) enrolled by this playbook. You must be careful to persist all of these files for the next time you run this playbook, otherwise you will be unable to administer your IBM Blockchain Platform network.-
If you wish to use this network for development purposes, you can import these JSON files into a wallet using the IBM Blockchain Platform extension for Visual Studio Code.
For more information on this task, follow the process to create a new Fabric Environment documented here: https://github.com/IBM-Blockchain/blockchain-vscode-extension#connecting-to-another-instance-of-hyperledger-fabric
-
If you are using the IBM Blockchain Platform on IBM Cloud, you do need to import these JSON files into your wallet using the web console. You will then need to assiociate each node with the correct identity. If you do not do this, then you will be unable to administer the nodes using the web console.
-
Apache-2.0