copy来的,这里记录一下

1. 升级系统: sudo apt-get upgrade
2. 安装docker
下载docker-ce: https://download.docker.com/linux/ubuntu/dists/xenial/pool/stable/amd64/docker-ce_18.03.1~ce-0~ubuntu_amd64.deb
sudo dpkg -i docker-ce_18.03.1~ce-0~ubuntu_amd64.deb
sudo groupadd docker
sudo usermod -aG docker <YouUser>

3. 安装docker-compose
sudo curl -L "https://github.com/docker/compose/releases/download/1.22.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

4.

5.1 安装与设置go语言开发环境
sudo tar -zxf go1.10.1.linux-amd64.tar.gz -C /usr/local/
vim ~/.bash_aliases
export GOROOT=/usr/local/go
export GOPATH=/home/jya/go
export GOBIN=$GOPATH/bin/
export PATH=.:$PATH:$GOROOT/bin:$GOBIN
export PATH=${PATH}:/home/jya/src/fabric-samples/bin

5.2下载源码
https://github.com/hyperledger/fabric-sdk-java.git
https://github.com/hyperledger/fabric-sdk-go.git
https://github.com/hyperledger/fabric-samples.git
https://github.com/hyperledger/fabric.git

6. 安装基本工具: sudo apt-get install -y build-essential git make curl unzip g++ libtool openssl go-dep
sudo apt-get install python-pip
sudo pip install --upgrade pip
go get golang.org/x/tools/cmd/goimports

cd $GOPATH/src/golang.org/x/
git clone https://github.com/golang/tools.git
go install golang.org/x/tools/go/packages
go install golang.org/x/tools/imports
go install golang.org/x/tools/cover
go install golang.org/x/tools/go/loader

mkdir $GOPATH/src/golang.org/ && cd $GOPATH/src/github.com/
git clone https://github.com/golang/lint.git
go install golang.org/x/lint/golint

mkdir $GOPATH/src/github.com/maxbrunsfeld/
cd $GOPATH/src/github.com/maxbrunsfeld/
git clone https://github.com/maxbrunsfeld/counterfeiter.git
go install github.com/maxbrunsfeld/counterfeiter

mkdir $GOPATH/src/github.com/axw && cd $GOPATH/src/github.com/axw
git clone https://github.com/axw/gocov.git
go install github.com/axw/gocov
go install github.com/axw/gocov/gocov (必须执行)

mkdir $GOPATH/src/github.com/vektra && cd $GOPATH/src/github.com/vektra
git clone https://github.com/vektra/mockery.git
go install github.com/vektra/mockery
go install github.com/vektra/mockery/cmd/mockery

mkdir $GOPATH/src/github.com/golang && cd $GOPATH/src/github.com/golang
git clone https://github.com/golang/protobuf.git
make all
cp $GOPATH/bin/protoc-gen-go $GOPATH/src/github.com/hyperledger/fabric/.build/docker/gotools/bin/

cd $GOPATH/src/github.com/golang
git clone https://github.com/golang/dep.git
go install github.com/golang/dep
go install github.com/golang/dep/cmd/dep

注意: dns-nameservers 10.41.132.9 有时域名解析失败,建议采用 10.30.1.9和8.8.8.8

7. 设置docker守护进程的代理

8. make all ,
如果在执行check_deps时报错,可以将./scripts/check_deps.sh文件中 dep version dep check两个命令注释掉。

部署fabric多机板
1. sudo mkdir -p /etc/hyperledger/fabric/ && sudo chown -R jya /etc/hyperledger/

2. 根据网络拓扑创建crypto-config.yaml配置文件,该文件可以以fabric-samples/first-network/crypto-config.yaml文件为蓝本,或者直接使用该文件。
3.生成相关材料: cryptogen generate --config=./crypto-config.yaml --output ./crypto-config 。执行命令后,会在当前目录下生成文件夹 crypto-config,包含节点用户的秘钥以及证书文件,
4. 通过scp命令将crypto-config文件夹拷贝到其它设备的/etc/hyperledger/fabric 目录下

5 .创建/etc/hyperledger/fabric/configtx.ymal文件,该文件可以以fabric-samples/first-network/configtx.ymal文件为蓝本,或者直接使用该文件。

6. 根据configtx.ymal生成创世区块以及通道等配置信息(位于10.43.33.120机器上)
6.0 设置环境变量:export FABRIC_CFG_PATH=/etc/hyperledger/fabric
6.1 创建channel-artifacts目录: mkdir -p /etc/hyperledger/fabric/channel-artifacts
6.2 进入该目录: cd /etc/hyperledger/fabric/channel-artifacts
6.3 创建创世区块: configtxgen -profile TwoOrgsOrdererGenesis -outputBlock genesis.block
6.4 .创建通道事物: export CHANNEL_NAME=mychannel && configtxgen -profile TwoOrgsChannel -outputCreateChannelTx ./channel.tx -channelID $CHANNEL_NAME
注意: 可以将mychannel替换成需要的通道名。
6.5.定义org1的anchor peer: configtxgen -profile TwoOrgsChannel -outputAnchorPeersUpdate ./Org1MSPanchors.tx -channelID $CHANNEL_NAME -asOrg Org1MSP
6.6.定义org2的anchor peer: configtxgen -profile TwoOrgsChannel -outputAnchorPeersUpdate ./Org2MSPanchors.tx -channelID $CHANNEL_NAME -asOrg Org2MSP
将会生成以下文件:channel.tx genesis.block Org1MSPanchors.tx Org2MSPanchors.tx

7. 修改每台机器上的/etc/hosts文件,添加以下内容(需要根据自己的IP和网络拓扑决定)
10.43.33.120 orderer.example.com
10.43.33.122 peer0.org1.example.com
10.43.33.122 peer0.org2.example.com
10.43.33.125 peer1.org1.example.com
10.43.33.125 peer1.org2.example.com

8. 准备order节点启动所需的材料
orderer 节点的执行环境目录下必须有以下文件及文件夹:./crypto-config、./msp、./tls、orderer.yaml、genesis.block
orderer.yaml文件可以参考fabric-samples/config/orderer.yaml 文件,注意:
需要将 ListenAddress: 127.0.0.1 改成 ListenAddress: 0.0.0.0
需要将 TwoOrgsOrdererGenesis
cd /etc/hyperledger/fabric/
cp channel-artifacts/genesis.block channel-artifacts/
cp -r ./crypto-config/ordererOrganizations/example.com/orderers/orderer.example.com/msp/ ./
如果上述命令启动orderer时报错,可以考虑执行下面的命令: cp -r ./crypto-config/ordererOrganizations/example.com/users/Admin@example.com/msp/ .

cp -r ./crypto-config/ordererOrganizations/example.com/orderers/orderer.example.com/tls/ ./
创建日志目录: sudo mkdir -p /var/hyperledger/ && sudo chown -R jya /var/hyperledger/
启动orderer节点: orderer start
注意: 如果报 [orderer/commmon/multichannel] newLedgerResources -> PANI 004 Error creating channelconfig bundle: initializing channelconfig failed: could not create channel Orderer sub-group config: 以下错误,则需要删除 /data/hyperledger/目录,具体见orderer.yaml文件中的FileLedger的配置项

注意: 需要将 orderer.yaml配置文件中的 LocalMSPID: SampleOrg改成 LocalMSPID: OrdererMSP,否则有可能报

启动order节点: orderer start

9. 启动peer0.org1节点。
peer 节点的执行环境目录下必须有以下文件及文件夹:./msp、./tls、core.yaml、channel.tx 、 core.yaml
9.1 在peer创建/etc/hyperledger/fabric/ 目录:
sudo mkdir -p /etc/hyperledger/fabric/ && sudo chown -R jya /etc/hyperledger/ 。
9.2 创建core.yaml配置文件,该文件可以以fabric-samples/config/core.yaml文件为蓝本,或者直接使用该文件。
9.3 拷贝证书及可执行文件(在10.43.33.120机器上执行以下命令):
scp -r ./crypto-config/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/ 10.43.33.122:/etc/hyperledger/fabric/
scp -r ./crypto-config/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/msp/ 10.43.33.122:/etc/hyperledger/fabric/
拷贝peer可执行文件: scp -r ./peer 10.43.33.122:/etc/hyperledger/fabric/
9.4 创建日志目录: sudo mkdir -p /var/hyperledger/ && sudo chown -R jya /var/hyperledger/
9.5 启动peer节点: peer node start

10. 启动peer0.org2节点。
peer 节点的执行环境目录下必须有以下文件及文件夹:./msp、./tls、core.yaml、channel.tx 、 core.yaml
9.1 在peer创建/etc/hyperledger/fabric/ 目录:
sudo mkdir -p /etc/hyperledger/fabric/ && sudo chown -R jya /etc/hyperledger/ 。
9.2 创建core.yaml配置文件,该文件可以以fabric-samples/config/core.yaml文件为蓝本,或者直接使用该文件。
scp bin/peer config/core.yaml 10.43.33.125:/etc/hyperledger/fabric/
9.3 拷贝证书信息(在10.43.33.120机器上执行以下命令):
scp -r ./crypto-config/peerOrganizations/org2.example.com/peers/peer0.org2.example.com/tls/ 10.43.33.125:/etc/hyperledger/fabric/
scp -r ./crypto-config/peerOrganizations/org2.example.com/peers/peer0.org2.example.com/msp/ 10.43.33.125:/etc/hyperledger/fabric/
scp bin/peer config/core.yaml 10.43.33.125:/etc/hyperledger/fabric/(在10.43.33.119机器上执行命令)
9.5 创建日志目录: sudo mkdir -p /var/hyperledger/ && sudo chown -R jya /var/hyperledger/
9.5 启动peer节点: peer node start

11. 在peer0.org1节点(10.43.33.122)上创建并加入channel
export CORE_PEER_LOCALMSPID="Org1MSP"
export CORE_PEER_MSPCONFIGPATH=/etc/hyperledger/fabric/crypto-config/peerOrganizations/org1.example.com/users/Admin@org1.example.com/msp
peer channel create -o orderer.example.com:7050 -c mychannel -f ./channel.tx --tls true --cafile /etc/hyperledger/fabric/crypto-config/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem 注意:如果报错,则需要却掉 --tls true 选项。
加入channel: peer channel join -b mychannel.block

12 更新peer0.org1的anchor节点
export FABRIC_CFG_PATH=/etc/hyperledger/fabric
peer channel update -o orderer.example.com:7050 -c $CHANNEL_NAME -f ./channel-artifacts/Org1MSPanchors.tx --cafile /etc/hyperledger/fabric/crypto-config/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem

13. 在peer0.org1节点(10.43.33.122)上安装并初始化chainchdoe(建议最好打包chaincode再安装,而不是直接调用peer chaincode install命令,否则有可能导致其它节点同样的chaincode无法实例化)
chaincode一般放在GOPATH/src目录当中,并且引用时需要使用与GOATH/src的相对路径, -p参数尽量放在最后。
  安装chaincode: peer chaincode install -n mychannel -v 1.0 -p chaincode/chaincode_example02/go
初始化chaincode: peer chaincode instantiate -o orderer.example.com:7050 -C mychannel -n mychannel -c '{"Args":["init","A","10","B","10"]}' -P "OR ('Org1MSP.member')" -v 1.0

14. 调用chaincode: $ peer chaincode query -C mychannel -n mychannel -c '{"Args":["query","A"]}'

常见错误:
创建channel时报错:
Error: failed to create deliver client: orderer client failed to connect to orderer.example.com:7050: failed to create new connection: context deadline exceeded
可能是因为创建channel时指定了 --tls true 参数,去掉即可。

错误描述:
[channel: mychannel] Rejecting broadcast of config message from 10.43.33.122:45346 because of error: Failed to reach implicit threshold of 1 sub-policies, required 1 remaining: permission denied
解决办法: 将orderer.yaml配置文件中的 LocalMSPID: SampleOrg改成 LocalMSPID: OrdererMSP,

错误描述:
在org1组织的peer0节点上加入通道(peer channel join -b mychannel.block)时,报错:
MSP error: expected MSP ID SampleOrg, received Org1MSP
姐姐办法,将 core.yaml配置文件中的 LocalMSPID: SampleOrg改成 LocalMSPID:Org1MSP,

错误描述:
安装chaincode时报错: Error: error getting chaincode code mychannel: <go, [env]>: failed with error: "exec: not started"
解决拌饭: 可能是因为没有安装go语言开发环境。

ubuntu1604 golang环境的更多相关文章

  1. mac 下配置protobuf 3.0 golang环境

    protobuf 3.0  与 之前的 protobuf 2.6 的语法是不一样的.需要重新安装一下,本机的环境是 OS X Yosemite  10.10.2 1. 不采用home brew安装,用 ...

  2. CentOS6.5上golang环境配置

    CentOS6.5上golang环境配置 一.下载和解压go环境包 >>cd /usr/local/src/ >>wget -c http://golangtc.com/sta ...

  3. CentOS6.4安装Golang环境

    什么是Go? Go是一门并发支持.垃圾回收的编译型的系统编程语言,目的是为了创造一门具有在静态编译语言的高性能和动态语言的高效开发之间拥有良好平衡点的一门编程语言. Go的主要特点有哪些? 类型安全和 ...

  4. golang环境搭建

    golang环境搭建 好久没写博客了,最近加班好厉害,加到自己都觉得不太适合这个行业了,每天头都是沉甸甸的,可惜今年注定不是收获的季节. 最近忙里偷闲在学习nodejs,赶巧看到golang的文章,一 ...

  5. golang环境

    Golang是谷歌开发的一款开源性语言,暂时比较方便的IDE有Inteillj Idea.LiteIDE.Eclipse(Golipse)等,使用起来比较方便的IDE:LiteIDE和Inteillj ...

  6. IntelliJ IDEA开发golang环境配置

    IntelliJ IDEA开发golang环境配置 首先把GO安装好...(自行安装,附上一篇我之前写的MAC安装GO) 安装IntelliJ IDEA,下载地址: https://www.jetbr ...

  7. linux上java和golang环境变量的设置

    JAVA环境变量   (1).打开~/.bashrc完成环境配置( 作用类似于/etc/bashrc, 只是针对用户自己而言,不对其他用户生效.)       文件追加            expo ...

  8. Ubuntu下安装Rabbitmq和golang环境

    安装及配置Rabbitmq 1. 安装: sudo apt-get install rabbitmq-server 2. 启动web管理插件 sudo rabbitmq-plugins enable ...

  9. golang 环境一键式配置

    在window下,通过以下bat,自动设置环境变量,启动终端,并cd到gopath目录 set goroot=c:\go set gopath=d:\go @start "start gol ...

随机推荐

  1. Vmworkstation启用错误

    无法打开内核设备"\\.\Global\vmx86":系统找不到指定的文件. 是否在安装 VMwareWorksation 后重新引到 ? 问题解决   无法连接 MKS:套接字连 ...

  2. flask 虚拟换将安装

    1.1.  1.4虚拟环境的安装 1.1.1. 安装虚拟环境 1.1.1.1. 安装 注意:这里必须使用pip3 安装. sudo pip3 install virtualenv sudo pip3 ...

  3. ubuntu16.04利用deb包安装mysql

    https://blog.csdn.net/zht741322694/article/details/79013093

  4. Intellij IDEA 配置Tomcat远程调试

    一.前言 在服务器端开发过程中,由于服务器环境差异导致运行结果不符合预期. 所以就需要到IDEA Debug 服务器代码.看起来貌似很高大上的事情. 今天就说说使用Intellij IDEA 配置的方 ...

  5. Jenkins官方社区携手灵雀云成功举办Jenkins Meetup

    10月27日,由 Jenkins 官方社区和灵雀云主办的 Jenkins 插件开发 Meetup 在北京中科曙光大厦成功举办.这是Hacktoberfest(即 Hack October Festiv ...

  6. HashMap 源码分析

    static final int DEFAULT_INITIAL_CAPACITY = 16;  默认容量 static final int MAXIMUM_CAPACITY = 1073741824 ...

  7. keil在线烧录突然提示 No target connected #

    keil在线烧录突然提示 No target connected 运行环境 IDE:keil uvsion5 微处理器:STM32F0xx 系列 烧录器:ST-LINK/V2 问题描述 烧录新程序并进 ...

  8. Ubuntu 安装第三方工具

    1. pycharm  安装(链接:https://pan.baidu.com/s/1fIp-AhBmnPvqYW40140RLw     提取码:ukkv ) 1.运行以下命令安装 sh pycha ...

  9. px和em的区别, css权重

    PX特点:px像素(Pixel).相对长度单位.像素px是相对于显示器屏幕分辨率而言的. EM特点 1. em的值并不是固定的:2. em会继承父级元素的字体大小. 优先级:!important> ...

  10. Lamda Expression

    Expression<Func<Student, bool>> filter=s=>s.Name.Contains("a") && s ...