分步搭建HF区块链网络--部署fabric区块链--加入channel

2024-04-26 01:52

本文主要是介绍分步搭建HF区块链网络--部署fabric区块链--加入channel,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一.搭建网络规划

采用容器环境,搭建1个排序节点(Orderer)、2个对等节点(Peer),另外用 一个fabric-cli容器。实训中的绝大部分命令是通过该容器执行的。

容器名称设置

二. 配置HF网络证书

首先docker ps 检查镜像,确保镜像为空

1.生成crypto-config.yaml

使用showtemplate显示默认配置信息,并重定向保存到config子目录下的文件crypto-config.yaml。 具体命令如下:

mkdir -p ~/test/config
cd ~/test
cryptogen showtemplate > config/crypto-config.yaml

 2.用默认配置生成组织身份文件

cryptogen会创建crypto-config文件夹,并将生成的内容输出到crypto-config文件夹中。其中的内容按 照组织进行组织。 具体命令如下:

cryptogen generate --config config/crypto-config.yaml --output crypto-config

三. 生成系统组织的数字证书

1.编写排序节点(orderer)配置文件

编写排序配置文件,保存在config目录下,文件名crypto-config-orderer.yaml。

vim config/crypto-config-orderer.yaml

配置如下内容: 

# --------------------------------------------------------------------------- # "OrdererOrgs" - Definition of organizations managing orderer nodes
# ---------------------------------------------------------------------------
OrdererOrgs:- Name: OrdererDomain: example.comEnableNodeOUs: trueSpecs:- Hostname: ordererSANS:- localhost

 

2.生成排序节点组织身份文件 

使用如下命令:cryptogen generate --config config/crypto-config-orderer.yaml --output organizations

3.编辑生成组织1数字证书的配置文件

 编辑配置文件config/crypto-config-org1.yaml

vim config/crypto-config-org1.yaml
PeerOrgs:# ---------------------------------------------------------------------------# Org1# ---------------------------------------------------------------------------- Name: Org1Domain: org1.example.comEnableNodeOUs: trueTemplate:Count: 1SANS:- localhost# Start: 5# Hostname: {{.Prefix}}{{.Index}} # defaultUsers:Count: 1

 4.生成组织1身份文件

使用如下命令:cryptogen generate --config config/crypto-config-org1.yaml --output organizations

编辑生成组织2数字证书的配置文件

编辑配置文件config/crypto-config-org2.yaml

vim config/crypto-config-org2.yaml
PeerOrgs:
# ---------------------------------------------------------------------------
# Org2
# ---------------------------------------------------------------------------- Name: Org2Domain: org2.example.comEnableNodeOUs: trueTemplate:Count: 1SANS:- localhost# Start: 5# Hostname: {{.Prefix}}{{.Index}} # defaultUsers:Count: 1

 

生成组织2身份文件

使用如下命令:cryptogen generate --config config/crypto-config-org2.yaml --output organizations

四. 创建创世区块 (applicationchannel.block)

 1.编辑configtx.yaml

Fabric的configtxgen工具生成通道配置,对应的配置文件是configtx.yaml,文件内容可以参考Fabric默认的配置文件。

2.创建创世区块

执行如下步骤创建创世区块:

export CHANNEL_NAME=applicationchannel
echo ${CHANNEL_NAME}
configtxgen -configPath ./config -profile TwoOrgsApplicationGenesis -channelID${CHANNEL_NAME} -outputBlock channel-artifacts/${CHANNEL_NAME}.block

执行如下步骤创建创世区块:

ls channel-artifacts/ -al

执行结果如下:

五. 部署HF区块链网络

1.编辑Docker-compose文件

在fabric目录下,新建一个fabric-compose.yaml文件,用于创建docker集群。

文件内容为:fabric-compose.yaml

2.创建docker卷

检查docker卷是否存在,若存在删除:

docker volume ls

docker volume rm peer0.org1.example.com orderer.example.com olla 
执行以下命令:
docker volume create orderer.example.com
docker volume create peer0.org1.example.com
docker volume create peer0.org2.example.com

3.部署fabric容器

在config目录下添加core.yamlcp ~/fabric/config/core.yaml config/执行以下命令:
docker-compose -f fabric-compose.yaml up -d

查看

docker ps

六. 加入通道 

实现orderer和peer节点加入applicationchannel操作:

  1. orderer加入applicationchannel

  2. peer加入applicationchannel

首先查看docker进程docker ps

然后启动fabric-compose.yaml

docker-compose -f fabric-compose.yaml start

如果要是有报错问题可以用以下处理方式

先停止:

1.使用docker exec登录fabric-cli

执行以下命令:

docker exec -it fabric-cli bash

2.orderer节点加入通道 

执行以下命令:

//先执行这个
export CHANNEL_NAME=applicationchannel//在执行这个
osnadmin channel join --channelID $CHANNEL_NAME --config-block ./channel-artifacts/${CHANNEL_NAME}.block -o orderer.example.com:7053 --ca-file "$ORDERER_CA" --client-cert "$ORDERER_ADMIN_TLS_SIGN_CERT" --client-key "$ORDERER_ADMIN_TLS_PRIVATE_KEY"

3.Org1的peer0加入通道

执行以下命令:

export CORE_PEER_TLS_ENABLED=true 
export CORE_PEER_LOCALMSPID="Org1MSP"export CORE_PEER_TLS_ROOTCERT_FILE=${PWD}/organizations/peerOrganizations/org1.example.com/tlsca/tlsca.org1.example.com-cert.pemexport CORE_PEER_MSPCONFIGPATH=${PWD}/organizations/peerOrganizations/org1.example.com/users/Admin@org1.example.com/mspexport CORE_PEER_ADDRESS=peer0.org1.example.com:7051
peer channel join -b channel-artifacts/${CHANNEL_NAME}.block

4.Org2的peer0加入通道

执行以下命令:export CORE_PEER_TLS_ENABLED=true
export CORE_PEER_LOCALMSPID="Org2MSP"export CORE_PEER_TLS_ROOTCERT_FILE=${PWD}/organizations/peerOrganizations/org2.example.com/tlsca/tlsca.org2.example.com-cert.pemexport CORE_PEER_MSPCONFIGPATH=${PWD}/organizations/peerOrganizations/org2.example.com/users/Admin@org2.example.com/msp
export CORE_PEER_ADDRESS=peer0.org2.example.com:9051
peer channel join -b channel-artifacts/${CHANNEL_NAME}.block

5.验证通道加入情况

执行以下命令概览:
peer channel list

执行以下命令获取详细情况:
peer channel getinfo -c ${CHANNEL_NAME}

这篇关于分步搭建HF区块链网络--部署fabric区块链--加入channel的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/936403

相关文章

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Window Server2016加入AD域的方法步骤

《WindowServer2016加入AD域的方法步骤》:本文主要介绍WindowServer2016加入AD域的方法步骤,包括配置DNS、检测ping通、更改计算机域、输入账号密码、重启服务... 目录一、 准备条件二、配置ServerB加入ServerA的AD域(test.ly)三、查看加入AD域后的变

k8s部署MongDB全过程

《k8s部署MongDB全过程》文章介绍了如何在Kubernetes集群中部署MongoDB,包括环境准备、创建Secret、创建服务和Deployment,并通过Robo3T工具测试连接... 目录一、环境准备1.1 环境说明1.2 创建 namespace1.3 创建mongdb账号/密码二、创建Sec

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像

Python项目打包部署到服务器的实现

《Python项目打包部署到服务器的实现》本文主要介绍了PyCharm和Ubuntu服务器部署Python项目,包括打包、上传、安装和设置自启动服务的步骤,具有一定的参考价值,感兴趣的可以了解一下... 目录一、准备工作二、项目打包三、部署到服务器四、设置服务自启动一、准备工作开发环境:本文以PyChar

SSID究竟是什么? WiFi网络名称及工作方式解析

《SSID究竟是什么?WiFi网络名称及工作方式解析》SID可以看作是无线网络的名称,类似于有线网络中的网络名称或者路由器的名称,在无线网络中,设备通过SSID来识别和连接到特定的无线网络... 当提到 Wi-Fi 网络时,就避不开「SSID」这个术语。简单来说,SSID 就是 Wi-Fi 网络的名称。比如

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五

centos7基于keepalived+nginx部署k8s1.26.0高可用集群

《centos7基于keepalived+nginx部署k8s1.26.0高可用集群》Kubernetes是一个开源的容器编排平台,用于自动化地部署、扩展和管理容器化应用程序,在生产环境中,为了确保集... 目录一、初始化(所有节点都执行)二、安装containerd(所有节点都执行)三、安装docker-

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys