Source
Subjects
- CA-Server HW-Security
- Gen: Channel
- Gen: Blockchain
- Gen: Chaincode
- static leader election policy
- TLS
Infrastructure
- vCPU: 2
- RAM: 7GB
- HDD: 30GB
- OS: Ubuntu 16.04
# -*- mode: ruby -*-
# vi: set ft=ruby :
ENV['VAGRANT_DEFAULT_PROVIDER'] = 'virtualbox'
ENV["LC_ALL"] = "en_US.UTF-8"
Vagrant.configure("2") do |config|
config.vm.box = "ubuntu/xenial64"
config.vm.hostname = "fabric"
config.vm.network "public_network"
config.vm.base_address = "192.168.178.201"
config.vm.base_mac = "0800278A8081"
config.vm.synced_folder ".", "/vagrant"
config.disksize.size = '50GB'
# --------------------------------------------------------------------
config.vm.provider "virtualbox" do |vb|
vb.gui = false
vb.name = "Fabric"
vb.cpus = 2
vb.memory = 4096
end
# --------------------------------------------------------------------
end
$ sudo apt install curl
$ sudo apt install git
$ sudo apt install python-minimal
$ sudo apt install docker-ce
Study-Plan
- peer
- Genesis Block
- MSP
Settings-YAML
- container_name
- image
- ports
- depends_on
- networks
- command
- working_dir
- volumes
- environment
Commands
CMD_CA: sh -c 'fabric-ca-server start -b admin:adminpw'
CMD_Orderer: orderer
CMD_Peer: peer node start
CMD_CLI: /bin/bash
working_dir
WD_CA: KEIN
WD_Order: /opt/gopath/src/github.com/hyperledger/fabric/orderer
WD_Peer: /opt/gopath/src/github.com/hyperledger/fabric
WD_CLI: /opt/gopath/src/github.com/hyperledger/fabric/peer
volumes
./crypto-config/peerOrganizations/org1.example.com/ca/: /etc/hyperledger/fabric-ca-server-config
./config/: /etc/hyperledger/configtx
./crypto-config/ordererOrganizations/example.com/orderers/orderer.example.com/: /etc/hyperledger/msp/orderer
./crypto-config/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/: /etc/hyperledger/msp/peerOrg1
/var/run/: /host/var/run/
./config: /etc/hyperledger/configtx
./crypto-config/peerOrganizations/org2.example.com/users: /etc/hyperledger/msp/users
./crypto-config/peerOrganizations/org2.example.com/peers/peer1.org2.example.com/msp: /etc/hyperledger/msp/peer
./crypto-config/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls: /etc/hyperledger/msp/peer/tls
/var/run/: /host/var/run/
./crypto-config: /opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/
./../chaincode/: /opt/gopath/src/github.com/
environment
CA
FABRIC_CA_SERVER_CA_NAME= ca.example.com
FABRIC_CA_HOME= /etc/hyperledger/fabric-ca-server
FABRIC_CA_SERVER_CA_CERTFILE= /etc/hyperledger/fabric-ca-server-config/ca.org1.example.com-cert.pem
FABRIC_CA_SERVER_CA_KEYFILE= /etc/hyperledger/fabric-ca-server-config/4239aa0dcd76daeeb8ba0cda701851d14504d31aad1b2ddddbac6a57365e497c_sk
Orderer
FABRIC_LOGGING_SPEC= info
ORDERER_GENERAL_LISTENADDRESS= 0.0.0.0
ORDERER_GENERAL_GENESISMETHOD= file
ORDERER_GENERAL_LOCALMSPID= OrdererMSP
ORDERER_GENERAL_GENESISFILE= /etc/hyperledger/configtx/genesis.block
ORDERER_GENERAL_LOCALMSPDIR= /etc/hyperledger/msp/orderer/msp
Peer
CORE_VM_ENDPOINT= unix:///host/var/run/docker.sock
CORE_LOGGING_PEER= debug
CORE_CHAINCODE_LOGGING_LEVEL= debug
CORE_PEER_ID= peer0.org2.example.com
CORE_PEER_LOCALMSPID= Org2MSP
CORE_PEER_MSPCONFIGPATH= /etc/hyperledger/msp/peer/
CORE_PEER_ADDRESS= peer0.org2.example.com:7051
CORE_VM_DOCKER_HOSTCONFIG_NETWORKMODE= startFiles_basic
CORE_LEDGER_STATE_STATEDATABASE= CouchDB
CORE_LEDGER_STATE_COUCHDBCONFIG_COUCHDBADDRESS= couchdbOrg2Peer0:5984
CORE_LEDGER_STATE_COUCHDBCONFIG_USERNAME= Org2Peer0
CORE_LEDGER_STATE_COUCHDBCONFIG_PASSWORD= password
CORE_PEER_TLS_KEY_FILE= /etc/hyperledger/msp/peer/tls/server.key
CORE_PEER_TLS_CERT_FILE= /etc/hyperledger/msp/peer/tls/server.crt
CORE_PEER_TLS_ROOTCERT_FILE= /etc/hyperledger/msp/peer/tls/ca.crt
CLI
CORE_PEER_TLS_KEY_FILE= /opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/server.key
CORE_PEER_TLS_CERT_FILE= /opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/server.crt
CORE_PEER_TLS_ROOTCERT_FILE= /opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/ca.crt
Work Life Cycle
Generate
- Generate: Crypto certificates, Genesis block, Transaction-Channel, Transaction-Anchor Peer
$ cryptogen generate --config=./crypto-config.yaml # generate crypto certificates
$ configtxgen -profile TwoOrgsOrdererGenesis -channelID byfn-sys-channel -outputBlock ./channel-artifacts/genesis.block # generate genesis block
$ configtxgen -profile TwoOrgsChannel -outputCreateChannelTx ./channel-artifacts/channel.tx -channelID mychannel # generate transaction: channel
$ configtxgen -profile TwoOrgsChannel -outputAnchorPeersUpdate ./channel-artifacts/Org1MSPanchors.tx -channelID mychannel -asOrg Org1MSP # generate transaction: anchor peer
Channel
Creating channel..
CA_FILE=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem
$ peer channel create -o orderer.example.com:7050 -c mychannel -f ./channel-artifacts/channel.tx --tls true --cafile $CA_FILE
Joining the channel...
$ peer channel join -b mychannel.block
Updating anchor peers for org1...
$ peer channel update -o orderer.example.com:7050 -c mychannel -f ./channel-artifacts/Org1MSPanchors.tx --tls true --cafile $CA_FILE
List Channels
$ peer channel list
Chaincode
- n:name chaincode, p:path to chaincode
Installing chaincode on peer0.org1...
$ peer chaincode install -n mycc -v 1.0 -l golang -p github.com/chaincode/chaincode_example02/go/
Instantiating chaincode on peer0.org2...
CA_FILE=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem
$ peer chaincode instantiate -o orderer.example.com:7050 --tls true --cafile $CA_FILE -C mychannel -n mycc -l golang -v 1.0 -c '{"Args":["init","a","100","b","200"]}' -P 'AND ('\''Org1MSP.peer'\'','\''Org2MSP.peer'\'')'
Attempting to Query peer0.org1 ...3 secs
$ peer chaincode query -C mychannel -n mycc -c '{"Args":["query","a"]}'
Sending invoke transaction on peer0.org1 peer0.org2...
CA_FILE=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem
TLS_FILES=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/ca.crt
ARG='{"Args":["invoke","a","b","10"]}'
$ peer chaincode invoke -o orderer.example.com:7050 --tls true --cafile $CA_FILE -C mychannel -n mycc --peerAddresses peer0.org1.example.com:7051 --tlsRootCertFiles $TLS_FILES --peerAddresses peer0.org2.example.com:7051 -c $ARG
discovery
discover saveConfig --configFile discoveryConfig.yaml --userKey $USERKEYFILE --userCert $USERCERTFILE --MSP Org1MSP
discover peers --configFile discoveryConfig.yaml --channel allarewelcome --server peer0.org1.example.com:7051 --chaincode ccForAll
Hyperledger Fabric - Building First Network
sudo apt-get install curl
sudo apt-get install golang-go
export GOPATH=$HOME/go
export PATH=$PATH:$GOPATH/bin
sudo apt-get install nodejs
sudo apt-get install npm
sudo apt-get install python
sudo apt-get install docker
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"
sudo apt-get update
apt-cache policy docker-ce
sudo apt-get install -y docker-ce
sudo apt-get install docker-compose
sudo apt-get upgrade
sudo curl -sSL https://goo.gl/6wtTN5 | sudo bash -s 1.1.0
sudo chmod 777 -R fabric-samples
cd fabric-samples/first-network
...
sudo ./byfn.sh generate
sudo ./byfn.sh up
sudo ./byfn.sh down