【推荐】 HyperLedger Fabric环境搭建、测试及注意事项 [详尽指导] [亲测有效]
系统:Ubuntu16.04 LTS
一、环境准备
1.1 Ubuntu下安装 crul
sudo apt install curl
curl是利用URL语法在命令行方式下工作的开源文件传输工具。它被广泛应用在Unix、多种Linux发行版中,并且有DOS和Win32、Win64下的移植版本。
作用:文件传输
1.2 安装 Docker and Docker Compose
Docker-compose是支持通过模板脚本批量创建Docker容器的一个组件。
- 前期准备:
由于apt官方库里的docker版本可能比较旧,所以先卸载可能存在的旧版本:
$ sudo apt-get remove docker-engine docker-ce docker.io
更新apt包索引:
$ sudo apt-get update
- 配置CE环境(Docker CE(Community Edition),即 Docker社区版)
配置apt允许以 HTTPS方式拉取镜像安装:
$ sudo apt-get install \
apt-transport-https \
ca-certificates \
curl \
software-properties-common添加Docker官方 GPG key:
$ curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
校验
9DC8 5822 9FC7 DD38 854A E2D8 8D81 803C 0EBF CD88
.$ sudo apt-key fingerprint 0EBFCD88
- 利用如下命令配置稳定镜像
$ sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"
- 安装Docker
- 更新apt包索引
$ sudo apt-get update
- 安装最新版Docker
sudo apt-get install docker-ce
s
- 验证Docker是否已经安装成功
$ sudo docker run hello-world
此命令会下载一个测试镜像,并且启动一个container来运行该镜像,打印一些信息后退出。
可参考官方教程:https://docs.docker.com/install/linux/docker-ce/ubuntu/#supported-storage-drivers
至此,Docker在Ubuntu上已经安装成功!
1.3 安装GO和NodeJS
1.3.1 GO
安装go语言包:
$ curl -O https://storage.googleapis.com/golang/go1.10.1.linux-amd64.tar.gz
下载完成后,解压至/usr/local 目录下:
$ sudo tar -C /usr/local -xzf go1.10.1.linux-amd64.tar.gz
配置go语言环境变量:
进入.bashrc 配置环境变量:
$ sudo vim ~/.bashrc
或者是:
$ sudo vim /etc/profile
在最后面加入如下代码:
export GOPATH=/usr/local/GO
export PATH=$GOPATH/bin:$PATH
保存,退出。
使环境变量生效:
$ source ~/.bashrc
或者是:
$ source /etc/profile
查看版本号后没问题,说明配置成功。
1.3.2 node.js
下载node.js
$ curl -sL https://deb.nodesource.com/setup_8.x | sudo -E bash
安装node.js
$ sudo apt-get install -y nodejs
检查版本:
二、Fabric 安装
2.1 Fabric 源码下载
首先建立对应的目录,然后进入该目录,使用Git命令下载源码:
mkdir -p ~/go/src/github.com/hyperledger
cd ~/go/src/github.com/hyperledger
git clone https://github.com/hyperledger/fabric.git
由于Fabric一直在更新,所有我们并不需要最新最新的源码,需要切换到v1.0.0版本的源码即可:
cd ~/go/src/github.com/hyperledger/fabric
git checkout -b v1.0.0
我们可以看到fabric源码下有许多文件。我们进入/examples/e2e_cli文件夹下。
通过如下命令,下载镜像:
sudo download-dockerimages.sh -c x86_64-1.0. -f x86_64-1.0.
下载完后,通过 docker images 查看版本即可。
至此fabric环境已经搭建完成。
三、大坑集锦
3.1 权限问题
出现以下问题:
Warning: failed to get default registry endpoint from daemon (Got permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.sock: Get http://%2Fvar%2Frun%2Fdocker.sock/v1.38/info: dial unix /var/run/docker.sock: connect: permission denied). Using system default: https://index.docker.io/v1/
Got permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.sock: Post http://%2Fvar%2Frun%2Fdocker.sock/v1.38/images/create?fromImage=hyperledger%2Ffabric-peer&tag=latest: dial unix /var/run/docker.sock: connect: permission denied
Got permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.sock: Post http://%2Fvar%2Frun%2Fdocker.sock/v1.38/images/hyperledger/fabric-peer:latest/tag?repo=hyperledger%2Ffabric-peer&tag=latest: dial unix /var/run/docker.sock: connect: permission denied
当在查询docker 版本时,也会出现类似错误:
Got permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.sock: Get http://%2Fvar%2Frun%2Fdocker.sock/v1.38/version: dial unix /var/run/docker.sock: connect: permission denied
这主要就是未获得root权限,所造成的错误。
解决方法:
授予root权限即可。
sudo ./download-dockerimages.sh
3.2 版本问题
如果直接获取最新版本,最后会出现如下问题:
Error response from daemon: manifest for hyperledger/fabric-javaenv:latest not found
原因:主要是因为一些组件还没有更新到最新版本,只有几个组建有最新版本。所以下载组件时要加上版本号。为了学习资料较全的v1.0.0,故我下载的是1.0.0版本。
sudo ./download-dockerimages.sh -c x86_64-1.0. -f x86_64-1.0.
===> List out hyperledger docker images
hyperledger/fabric-ccenv <none> 6acf31e2d9a4 weeks ago .43GB
hyperledger/fabric-orderer <none> 4baf7789a8ec weeks ago 152MB
hyperledger/fabric-peer <none> 82c262e65984 weeks ago 159MB
hyperledger/fabric-couchdb <none> 3092eca241fc months ago .61GB
hyperledger/fabric-tools latest 0403fd1c72c7 months ago .32GB
hyperledger/fabric-tools x86_64-1.0. 0403fd1c72c7 months ago .32GB
hyperledger/fabric-couchdb latest 2fbdbf3ab945 months ago .48GB
hyperledger/fabric-couchdb x86_64-1.0. 2fbdbf3ab945 months ago .48GB
hyperledger/fabric-kafka latest dbd3f94de4b5 months ago .3GB
hyperledger/fabric-kafka x86_64-1.0. dbd3f94de4b5 months ago .3GB
hyperledger/fabric-zookeeper latest e545dbf1c6af months ago .31GB
hyperledger/fabric-zookeeper x86_64-1.0. e545dbf1c6af months ago .31GB
hyperledger/fabric-orderer latest e317ca5638ba months ago 179MB
hyperledger/fabric-orderer x86_64-1.0. e317ca5638ba months ago 179MB
hyperledger/fabric-peer latest 6830dcd7b9b5 months ago 182MB
hyperledger/fabric-peer x86_64-1.0. 6830dcd7b9b5 months ago 182MB
hyperledger/fabric-javaenv latest 8948126f0935 months ago .42GB
hyperledger/fabric-javaenv x86_64-1.0. 8948126f0935 months ago .42GB
hyperledger/fabric-ccenv latest 7182c260a5ca months ago .29GB
hyperledger/fabric-ccenv x86_64-1.0. 7182c260a5ca months ago .29GB
hyperledger/fabric-ca latest a15c59ecda5b months ago 238MB
hyperledger/fabric-ca x86_64-1.0. a15c59ecda5b months ago 238MB
3.3 更改获取的源
如果是国外的源会很慢很慢,需要保证apt source是国内的。具体做法:
方法一:
sudo vi /etc/apt/sources.list
打开这个apt源列表,如果其中看到是http://us.xxxxxx之类的,那么就是外国的,如果看到是http://cn.xxxxx之类的,那么就不用换的。我的是美国的源,所以需要做一下批量的替换。在命令模式下,输入:
:%s/us./cn./g
就可以把所有的us.改为cn.了。然后输入:wq即可保存退出。
方法二:
界面操作,后续补充。
3.4 测试e2e网络时,ERR 001:
最常见的就是ERRO 001 cannot run peer because error when setting up MSP from directory /opt/gopath/src/......。出现这个问题主要是由于镜像没下全以及缺少ltdl.h文件的原因,当然还要确定你的fabric版本与你下的镜像版本一致,我使用的是v1.0.0。
解决方式如下:
1.确定fabric版本与你下的镜像版本一致(推荐使用v1.0.0):
在fabric目录下输入git checkout v1.0.0
通过输入docker images查看你已下载的镜像。
不正确的话则在fabric目录下输入git clone https://gerrit.hyperledger.org/r/fabric -b v1.0.0
确保你下的版本是v1.0.0
2.erro 001的错误往往是由无法正确生成公私钥和证书的原因,测试如下:
参考资料:
环境配置:
1.https://blog.csdn.net/agecntao/article/details/78580746
2.https://blog.csdn.net/xxxslinyue/article/details/79396618
3.https://blog.csdn.net/sun13465816527/article/details/80393119
4.https://blog.csdn.net/tiandiwuya/article/details/78771475
6.https://blog.csdn.net/sinat_36742186/article/details/78510191
7.http://www.netkiller.cn/journal/hyperledger.html
错误解决:
1.https://blog.csdn.net/mx1222/article/details/80888830 不太推荐
【时间仓促,如有错误,欢迎指正! || 欢迎一起学习交流, 请在评论区留言!】
【本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。】
【转载请联系博主,同意后务必注明出处:http://www.cnblogs.com/X-knight/】
【推荐】 HyperLedger Fabric环境搭建、测试及注意事项 [详尽指导] [亲测有效]的更多相关文章
- Hyperledger Fabric 环境搭建(2)
上一篇https://www.cnblogs.com/xdyixia/p/11738096.html 介绍了Hyperledger Fabric环境中各种软件安装和源码编译,这一篇介绍快速运行一个简单 ...
- Hyperledger Fabric 环境搭建(1)
1,Fabric的程序模块组成 Fabric不是一个单独的程序而是由一组模块组成,这些模块中的每一个都是一个可独立运行的可执行文件. (1)peer 主节点模块,负责存储区块链数据,运行维护链码: ( ...
- 联盟链初识以及Fabric环境搭建流程
这篇文章首先简单介绍了联盟链是什么,再详细的介绍了Fabric环境搭建的整个流程. 区块链分类: 以参与方式分类,区块链可以分为:公有链.联盟链和私有链. 定义: 我们知道区块链就是一个分布式的,去中 ...
- Ubuntu下配置Hyperledger Fabric环境
在win10系统的台式机上安装配置Hyperledger Fabric环境 安装Ubuntu 16.04 双系统 镜像下载地址:https://www.ubuntu.com/download/desk ...
- Hyperledger Fabric 手动搭建【区块链学习三】
Hyperledger Fabric 手动搭建 前面我们学习了区块链是什么.还有自动搭建学习东西我们就要从简单到深入(入门到放弃),现在自动部署已经跑通了接下来就是手动搭建Fabric 网络可以更好的 ...
- 大数据基础-2-Hadoop-1环境搭建测试
Hadoop环境搭建测试 1 安装软件 1.1 规划目录 /opt [root@host2 ~]# cd /opt [root@host2 opt]# mkdir java [root@host2 o ...
- Nginx配置多个基于域名的虚拟主机+实验环境搭建+测试
标签:Linux 域名 Nginx 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://xpleaf.blog.51cto.com/9 ...
- 7.搭建hyperledger fabric环境及启动——2019年12月12日
2019年12月12日13:05:16 声明:从网络中学习整理实践而来. 1.介绍fabric Fabric 是一个面向企业应用的区块链框架,基于 Fabric 的开发可以粗略分为几个层面: 1. 参 ...
- 深入理解Fabric环境搭建的详细过程
博主之前的文章都是教大家怎么快速的搭建一个Fabric的环境,但是其中大量的工作都隐藏到了官方的脚本中,并不方便大家深入理解其中的过程,所以博主这里就将其中的过程一步步分解,方便大家! 前面的准备工作 ...
随机推荐
- python 中的csv读写
1.首先 import csv 2.读一个csv文件 data = open(filename) lines = csv.reader(data) #reader 函数和 dirtreader函数的 ...
- java 通过HttpURLConnection与servlet通信
研究了一天才搞清楚,其实挺简单的,在这里记录下,以便以后参考. 一.创建一个servlet项目 主要包括(WEB-INF)里面有classes文件夹.lib文件夹.web.xml文件. 将写好的ser ...
- JSON Patch
1.前言 可以这么说的是,任何一种非强制性约束同时也没有"标杆"工具支持的开发风格或协议(仅靠文档是远远不够的),最终的实现上都会被程序员冠上"务实"的名头,而 ...
- git merge与 git rebase区别及实例
接Git分支创建与合并,在分支合并时,有两种方式:git merge 和git rebase. git merge:将两个分支,合并提交为一个新提交,并且新提交有2个parent. git rebas ...
- TensorFlow-谷歌深度学习库 文件I/O Wrapper
这篇文章主要介绍一下TensorFlow中相关的文件I/O操作,我们主要使tf.gfile来完成. Exists tf.gfile.Exists(filename) 用来判断一个路径是否存在,如果存在 ...
- Docker容器发布spring boot项目
一.安装Docker环境 yum install docker 安装完成后,使用下面的命令来启动 docker 服务,并将其设置为开机启动: systemctl start docker.servic ...
- java中Iterator和ListIterator的区别与联系
首先,为什么需要使用迭代器Iterator,原有的for循环和for each不能满足需求吗? 那是因为Iterator模式是用于遍历集合类的标准访问方法.它可以把访问逻辑从不同类型的集合类中抽象出来 ...
- ehcache与redis的比较与应用场景分析(转)
ehcache直接在jvm虚拟机中缓存,速度快,效率高:但是缓存共享麻烦,集群分布式应用不方便.redis是通过socket访问到缓存服务,效率比ecache低,比数据库要快很多,处理集群和分布式缓存 ...
- java中使用hashSet的特性,判断数组是否有重复值
public static boolean cheakRepeat(int[] array){ HashSet<Integer> hashSet = new HashSet<Inte ...
- 人工智能之基于face_recognition的人脸检测与识别
不久乘高铁出行,看见高铁火车站已经实现了"刷脸进站",而且效率很高,很感兴趣,今天抽时间研究一下,其实没那么复杂. 我基本上是基于https://github.com/ageitg ...