hyperledger-labs / microfab

Microfab is a containerized Hyperledger Fabric runtime for use in development environments
Apache License 2.0
76 stars 22 forks source link

microfab

'microfab' provides a single container image that allows you to quickly start Hyperledger Fabric when you are developing solutions. You can use it to rapidly iterate over changes to chaincode, and client applications. Configured with your selection of channels and orgs you want, it can be started and stopped in seconds.

To learn how to use Microfab as part of the development workflow, follow the smart contract part of the Hyperledger Fabric Sample's Full Stack Tutorial

Check the reference in this repo for details in other langauges.

asciicast

Tutorial

Check the Quick Start Tutorial - nothing to deployed smart contract in under 5minutes;

curl -sSL https://github.com/hyperledger-labs/microfab/releases/download/v0.0.18/microfab-linux-amd64 -o microfab
microfab start --log

Why microfab?

There are other 'form factors' of Fabric some are aimed at production/k8s deployments others more development focussed.

Depending on your circumstances, familiarity and requirements different tools may be better. After running with Microfab in the Full Stack AssetTransfer workshop - Microfab is particularly good for the earlier contract and SDK development phases.

What Fabric version does Microfab use?

The idea is to have branches per release of Fabric.

Reference

What Microfab can't do

Unable to connect errors

If you experience connection rejected type errors please check if your DNS is correctly able to resolve the nip.io addresses

ping server.127-0-0-1.nip.io
PING server.127-0-0-1.nip.io (127.0.0.1) 56(84) bytes of data.
64 bytes from localhost (127.0.0.1): icmp_seq=1 ttl=64 time=0.488 ms
64 bytes from localhost (127.0.0.1): icmp_seq=2 ttl=64 time=0.035 ms

Some DNS servcies reject the DNS rewriting that this service uses and causes problems as you might image with microfab's proxy. A feature we'd to add is a detailed list of all the ports that internal services are using, so you expose them directly. Help appreciated!

License

Apache-2.0