Hyperledger Fabric搭建测试网络

本文使用的Fabric版本:V2.5.4
Ubuntu系统:16.04LTS

  前序文章已经详细介绍了如何安装部署Hyperledger Fabric系统,这里不再赘述。本篇文章主要介绍如何使用Fabric的测试网络。在正式开始之前,有一点需要说明:

  • Hyperledger Fabric的完整安装路径如下:
$HOME/go/src/github.com/hyperledger/fabric

为了方便,下文cd命令中的路径从fabric开始书写,fabric之前的省略

1 启动/关闭测试网络

  为了方便开发人员学习及测试智能合约和DApp,fabric-samples文件中提供了一个测试网络test-network。

1.1 启动测试网络

进入fabric/scripts/fabric-samples/test-network,可以执行如下命令启动测试网络:

cd fabric/scripts/fabric-samples/test-network
./network.sh up

如果命令在执行过程中遇到“permission denied"提示,则使用sudo权限执行第二条命令:

sudo ./network.sh up

执行成功将看到以下提示信息:
在这里插入图片描述
从图中可以看到,这个测试网络包括一个Orderer节点、两个Peer节点和一个CLI客户端(这些都部署在docker容器中),其中这两个Peer节点分属两个组织:Org1和Org2。

1.2 关闭测试网络

可以使用以下命令关闭测试网络:

sudo ./network.sh down

Tips:测试网络关闭之后,创建的通道、部署的链码以及配置的环境变量都会失效,都要重新设置。

1.3 重启测试网络

可以使用如下命令重启测试网络:

sudo ./network.sh restart

2 创建通道

  通道提供一种通信机制,将指定的Peer和Orderer连接在一起,形成一个具有保密性的通信链路,进行数据隔离(区块数据只能存储在已加入到通道中的成员节点内)。
测试网络成功启动之后,就可以创建通道了。创建命令如下:

sudo ./network.sh createChannel

命令会默认创建一个名为"mychannel"的通道,并且将两个Peer节点加入该通道中。

Anchor peer set for org ‘Org1MSP’ on channel ‘mychannel’
Anchor peer set for org ‘Org2MSP’ on channel ‘mychannel’
Channel ‘mychannel’ joined

创建通道时,还可以指定通道的名字。命令如下:

//创建一个名为first_channel的通道
sudo ./network.sh crateChannel -c first_channel

通道名称遵循以下规则:

  • 由小写字母、点(.)和短横线(-)构成;并且字母开头;
  • 长度小于250字符

Hyperledger Fabric中通道、节点、组织之间的关系:

通道、节点和组织之间的关系可以用以下方式概括:每个参与方组织可以拥有一个或多个节点,节点可以属于一个或多个组织,而不同的组织可以通过一个或多个通道进行隔离和交互。每个通道的参与方可以通过Peer节点之间的共享账本实现数据的一致性和交易的隐私性。同时,Orderer节点作为整个网络的协调者,负责交易的排序和共识。

3 安装部署链码

  链码(Chaincode)就是Hyperledger Fabric中的智能合约,是一个可以对账本数据进行操作的可开发的组件程序。调用链码之前需要先安装部署,链码也部署在容器中。部署命令如下:

./network.sh deployCC -ccn basic -ccp ../asset-transfer-basic/chaincode-go -ccl go

该命令将会部署一个使用go语言编写的链码。其中:

  • ccn:表示链码的名字;
  • ccp:表示链码文件的地址;这是fabric-samples提供的链码案例。
  • ccl: 表示链码文件使用的语言;

链码部署的命令一定不能用sudo来执行。但如果在执行上述命令的时候出现如下错误:
go executable file not found in $PATH
在这里插入图片描述
权限不够错误
在这里插入图片描述可以通过修改~/go文件的权限来解决。具体如下:

sudo chmod -R 777 ~/go

4 peer CLI

  创建了网络之后,可以使用peer CLI操作网络,包括安装部署智能合约、调用智能合约以及更新通道等。只需要配置环境变量就可以使用peer CLI。具体如下:

4.1 配置peer CLI

(1) 将/fabric/scripts/fabric-samples/bin目录加入到环境变量PATH中。
第一种方法:通过/etc/profile文件配置
在这里插入图片描述
第二种方法:通过export命令
网络上很多资料给出的使用export配置环境变量的命令如下:

export PATH=${PWD}/../bin:$PATH

但是这里并不推荐这种写法。原因有以下两点:

  • 这个命令当中用到了PWD变量,即用户当前的工作路径。如果你当前的路径不是/fabric/scripts/fabric-samples/test-network 的话,那么最终添加到PATH中的路径就是错的。
  • 即使当前的工作路径为/fabric/scripts/fabric-samples/test-network,有些系统也无法映射到正确的路径。比如:
    在这里插入图片描述

如果想要使用export方法配置该环境变量的话,建议使用如下命令

//先跳转到fabric-samples文件所在的地址
cd /fabric/scripts/fabric-samples
export PATH=$PWD/bin:$PATH

(2) 配置FABRIC_CFG_PATH

//先跳转到fabric-samples文件所在的地址
cd /fabric/scripts/fabric-samples
export FABRIC_CFG_PATH=${PWD}/config/

(3) 配置Org1环境变量

要先进入test-network文件目录:

cd /fabric/scripts/fabric-samples/test-network

然后用命令行部署环境变量:

export CORE_PEER_TLS_ENABLED=true
export CORE_PEER_LOCALMSPID="Org1MSP"
export CORE_PEER_TLS_ROOTCERT_FILE=${PWD}/organizations/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/ca.crt
export CORE_PEER_MSPCONFIGPATH=${PWD}/organizations/peerOrganizations/org1.example.com/users/Admin@org1.example.com/msp
export CORE_PEER_ADDRESS=localhost:7051

接下来就可以使用peer CLI了。可以输入如下命令验证是否正确配置:

peer channel list

如果能返回刚才创建的“mychannel"信息(如下图),则说明peer CLI已经正确配置。
在这里插入图片描述
如果出现如下错误:

Error: error getting endorser client for invoke: endorser client failed to connect to localhost:7051: failed to create new connection: context deadline exceeded.

这是因为前面创建的Orderer、Peer节点都不存在了,可以使用docker ps -a查看一下。需要重新启动网络、创建通道、部署链码和配置环境变量。

4.2 说明

关于peer CLI有以下几点需要说明(后续补充):

  • peer CLI是用于与Fabric网络中的peer节点进行交互的命令行工具。上文示例中的peer CLI绑定的是Org1中的peer节点。如果需要绑定Org2中的peer节点,则需要重新配置环境变量。

  到目前为止,测试网络已经搭建完成。至于如何使用peer CLI调用智能合约,留待下一篇博客。

参考资料

  1. https://hyperledger-fabric.readthedocs.io/en/release-2.5/test_network.html
  2. https://blog.51cto.com/zhuxianzhong/7241974?articleABtest=0
  3. https://blog.51cto.com/zhuxianzhong/7242582?articleABtest=0
  4. https://blog.51cto.com/zhuxianzhong/7246193?articleABtest=0
  5. https://blog.csdn.net/qq_45179762/article/details/122217058
  6. https://blog.csdn.net/wybnmsl/article/details/113743268
  7. https://blog.csdn.net/Blockchain210/article/details/127707353

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/121373.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

24 行为型模式-访问者模式

1 访问者模式介绍 访问者模式在实际开发中使用的非常少,因为它比较难以实现并且应用该模式肯能会导致代码的可读性变差,可维护性变差,在没有特别必要的情况下,不建议使用访问者模式。 2 访问者模式原理 3 访问者模式实现 我们以超市购物为例,假设超市中的三类商品: 水果,糖…

JVM(二)

一,运行时数据区 Java虚拟机在运行Java程序过程中管理的内存区域,称之为运行时数据区。 1.1 程序计数器 程序计数器(Program Counter Register)也叫PC寄存器,每个线程会通过程序计数器记录当前要执行的的字节码指令的地址。 在加载阶段,虚拟机将字节码文件中的指令读取…

多线程面试相关知识点

文章目录 (一) 进程线程和协程的区别创建线程的4种方式1. 继承Thread类2. 实现runnable接口3. 实现Callable接口4. 线程池创建 runnable 和 callable 有什么区别线程的 run()和 start()有什么区别?线程之间的状态变化notify()和 notifyAll()有什么区别?j…

HPV感染的风险:闫会宁主任分析酒店环境中的常见因素

人类乳头瘤病毒(HPV)是一种普遍存在的病毒,其存在和传播方式多种多样。近年来,人们对于HPV的认识不断深入,知道其在酒店环境中的传播风险。本文将探讨哪些情况下在酒店可能感染HPV。 一、HPV的传播方式 HPV主要通过直接接触传播&#xff0c…

数据湖Iceberg介绍和使用(集成Hive、SparkSQL、FlinkSQL)

文章目录 简介概述作用特性数据存储、计算引擎插件化实时流批一体数据表演化(Table Evolution)模式演化(Schema Evolution)分区演化(Partition Evolution)列顺序演化(Sort Order Evolution&…

python:使用Scikit-image对遥感影像进行梯度特征提取(gradient)

作者:CSDN @ _养乐多_ 在本博客中,我们将介绍如何使用Scikit-Image来进行梯度特征提取(gradient),并且提供一个示例代码,演示了如何在单波段遥感图像上应用这些方法。 梯度特征是指用于表示图像中亮度或颜色变化的特征。它包括两个关键成分:梯度幅值和梯度方向。梯度幅…

RabbitMQ (4)

RabbitMQ (4) 文章目录 1. 死信的概念2. 死信的来源3. 死信代码案例3.1 TTL 过期时间3.2 超过队列最大长度3.3 拒绝消息 前言   上文我们已经学习完 交换机 ,知道了几个交换机的使用 ,下面我们来学习一下 死信队列 1. 死信的概念 先从概念解释上搞清楚这…

【C++】mapset的底层结构 -- AVL树(高度平衡二叉搜索树)

前面我们对 map / multimap / set / multiset 进行了简单的介绍,可以发现,这几个容器有个共同点是:其底层都是按照二叉搜索树来实现的。 但是二叉搜索树有其自身的缺陷,假如往树中插入的元素有序或者接近有序,二叉搜索…

漏洞复现-phpmyadmin_SQL注入 (CVE-2020-5504)

phpmyadmin SQL注入 _(CVE-2020-5504) 漏洞信息 CVE-2020-5504sql注入漏洞Phpmyadmin 5.00以下 描述 ​ phpMyAdmin是Phpmyadmin团队的一套免费的、基于Web的MySQL数据库管理工具。该工具能够创建和删除数据库,创建、删除、修改数据库表&…

Java学习 5.习题2.

练习题1:判断一个数字是偶数还是奇数 int num110;if(num1%20) {System.out.println("num1是一个偶数");}else{System.out.println("num1是一个奇数");} 练习题2:判断一个数是正数还是负数还是0 int num2-5;if(num2>0) {System.ou…

yarn install 这个命令安装如何加速

yarn install 命令用来安装项目依赖,其速度受多种因素影响,如网络速度、npm/yarn包的源服务器、以及本地缓存等。以下是一些可能帮助你加速 yarn install 的方法: 1. 使用国内镜像 如果你在中国,可以使用淘宝的 npm 镜像&#x…

【Javascript】json

目录 什么是json? 书写格式 json 序列化和反序列化 序列化 反序列化 什么是json? JSON(JavaScript Object Notation)是⼀种轻量级的数据交换格式,它基于JavaScript的⼀个⼦集,易于⼈的编写和阅读,也易于机器解析…

栈、队列、矩阵的总结

栈的应用 括号匹配 表达式求值(中缀,后缀) 中缀转后缀(机算) 中缀机算 后缀机算 总结 特殊矩阵 对称矩阵的压缩存储 三角矩阵 三对角矩阵 稀疏矩阵的压缩存储

OpenCV官方教程中文版 —— 傅里叶变换

OpenCV官方教程中文版 —— 傅里叶变换 前言一、原理二、Numpy 中的傅里叶变换三、OpenCV 中的傅里叶变换四、为什么拉普拉斯算子是高通滤波器? 前言 本小节我们将要学习: • 使用 OpenCV 对图像进行傅里叶变换 • 使用 Numpy 中 FFT(快速…

多线程线程池

线程安全问题 当多个线程同时操作同一个共享资源的时候,可能会出现结果不符合预期的问题 解决安全问题 方式一: 同步代码块 作用: 把访问共享资源的核心代码给上锁,以此保证线程安全 格式: synchronized(同步锁) { 访问共享资源的核心代…

unocss和tailwindcss css原子引擎

第一种tailwindcss: tailwindcss官网 https://tailwindcss.com/docs/grid-column 基本介绍及优点分析 Tailwind CSS 中文文档 - 无需离开您的HTML,即可快速建立现代网站 PostCss 处理 Tailwind Css 基本流程 PostCSS - 是一个用 JavaScript 工具和插…

67 内网安全-域横向smbwmi明文或hash传递

#知识点1: windows2012以上版本默认关闭wdigest,攻击者无法从内存中获取明文密码windows2012以下版本如安装KB2871997补丁,同样也会导致无法获取明文密码针对以上情况,我们提供了4种方式解决此类问题 1.利用哈希hash传递(pth,ptk等…

尚未解决:use_python()和use_virtualenv()的使用

reticulate包为Python和R之间的互操作性提供了一套全面的工具。该包包含以下功能: 以多种方式从R调用Python,包括RMarkdown、获取Python脚本、导入Python模块以及在R会话中交互使用Python。 R和Python对象之间的转换(例如,R和Pan…

2023年中国调音台产业链、产量及市场规模分析[图]

调音台是一种专业音频设备,用于混音、处理和控制音频信号。它通常用于音乐制作、现场演出、录音室以及广播等场景中。调音台允许用户调整不同声音来源的音频信号,使其在混音过程中达到理想的音质和平衡。调音台按信号出来方式可分为:模拟式调…

UVa10976 Fractions Again?!(分数拆分)

1、题目 2、题意 输入正整数 k k k,找到所有正整数 x ≥ y x \ge y x≥y,使得 1 k 1 x 1 y \frac{1}{k} \frac{1}{x} \frac{1}{y} k1​x1​y1​。 3、分析 既然要求找出所有的 x , y x,y x,y,枚举对象自然是 x , y x,y x,y了。可…