Peer节点命令

Peer node

start

启动一个Peer节点:

peer node start

status

获取当前节点的状态信息

peer node status

reset

重置当前节点加入的通道所有的数据到创世区块,意思就是说删除当前Peer接收到的所有区块信息。执行当前命令时,节点必须处于离线状态,当节点再次上线时,将会从Orderer或其他Peer节点处重新接收区块数据。

peer node reset

rollback

回滚当前Peer节点接收到的区块数据到指定的区块号。执行当前命令时,节点必须处于离线状态,当节点再次上线时,将会从Orderer或其他Peer节点处重新接收区块数据。

peer node rollback -b 需要回滚到的区块号 -c 指定的通道ID

Peer channel

这一部分涉及Peer节点对通道的操作

create

创建一个通道并将创世区块写入文件

peer channel create -c 通道ID -f channel.tx -f 超时值
#全局变量
--tls 是否使用TLS加密 --cafile CA证书路径 --certfile X509公钥文件路径 -o Orderer节点主机:端口
#例子
peer channel create -c mychannel --orderer orderer.example.com:7050 -f ./createchannel.txn -t 30s

fetch

获取一个具体区块信息并写入文件

peer channel fetch <newest|oldest|config|(number)> [输出文件路径名] -c 通道ID
#全局变量
--tls 是否使用TLS加密 --cafile CA证书路径 --certfile X509公钥文件路径 -o Orderer节点主机:端口
#例子
peer channel fetch newest mychannel.block -c mychannel --orderer orderer.example.com:7050
peer channel fetch 16 -c mychannel --orderer orderer.example.com:7050

getinfo

获取具体的通道信息

peer channel getinfo -c 通道ID
#全局变量
--tls 是否使用TLS加密 --cafile CA证书路径 --certfile X509公钥文件路径 -o Orderer节点主机:端口
#例子
peer channel getinfo -c mychannel

join

将一个指定的节点加入通道

peer channel join -b 包含创世区块的路径
#全局变量
--tls 是否使用TLS加密 --cafile CA证书路径 --certfile X509公钥文件路径 -o Orderer节点主机:端口
#例子
peer channel join -b ./mychannel.genesis.block

list

列出指定的节点已加入的通道

peer channel list
#全局变量
--tls 是否使用TLS加密 --cafile CA证书路径 --certfile X509公钥文件路径 -o Orderer节点主机:端口

signconfigtx

对文件系统中用于更新配置信息的文件签名

peer channel signconfigtx -f 文件
#全局变量
--tls 是否使用TLS加密 --cafile CA证书路径 --certfile X509公钥文件路径 -o Orderer节点主机:端口
#例子
peer channel signconfigtx -f updatechannel.tx

update

签名并发送配置更新文件到通道中,一般用于锚节点更新

peer channel update -c 通道ID -f 配置更新文件
#全局变量
--tls 是否使用TLS加密 --cafile CA证书路径 --certfile X509公钥文件路径 -o Orderer节点主机:端口
#例子
peer channel update -c mychannel -f ./updatechannel.txn -o orderer.example.com:7050

Peer chaincode

这一部分涉及Peer节点对链码的相关操作

install

打包链码数据为可部署的结构,并存储到当前Peer节点的路径,简而言之就是安装链码。

peer chaincode install -l 编写链码所使用的语言 -n 链码名称 -p 链码路径 -v 链码版本
#全局变量
--tls 是否使用TLS加密 --cafile CA证书路径 --certfile X509公钥文件路径 -o Orderer节点主机:端口
#例子
peer chaincode install -n mycc -v 1.0 -p github.com/hyperledger/fabric/examples/chaincode/go/chaincode_example02

instantiate

链码实例化

peer chaincode instantiate -C 通道ID -l 编写链码所使用的语言 -n 链码名称 -v 链码版本 -P 指定链码的策略 -E 指定对该用户链码进行背书的系统链码 -V 指定对该用户链码进行验证的系统链码
#全局变量
--tls 是否使用TLS加密 --cafile CA证书路径 --certfile X509公钥文件路径 -o Orderer节点主机:端口
#例子
peer chaincode instantiate -o orderer.example.com:7050 --tls --cafile $ORDERER_CA -C mychannel -n mycc -v 1.0 -c '{"Args":["init","a","100","b","200"]}' -P "AND ('Org1MSP.peer','Org2MSP.peer')"

invoke

调用链码的功能

peer chaincode invoke -C 通道ID -n 链码名称 -c 传入的参数
#全局变量
--tls 是否使用TLS加密 --cafile CA证书路径 --certfile X509公钥文件路径 -o Orderer节点主机:端口
#例子
peer chaincode invoke -o orderer.example.com:7050 -C mychannel -n mycc --peerAddresses peer0.org1.example.com:7051 --peerAddresses peer0.org2.example.com:9051 -c '{"Args":["invoke","a","b","10"]}'

list

如果指定通道,则列出已实例化的链码,否则列出所有已安装的链码

peer chaincode list -C 通道ID
--installed
--instantiated
#全局变量
--tls 是否使用TLS加密 --cafile CA证书路径 --certfile X509公钥文件路径 -o Orderer节点主机:端口
#例子
peer chaincode list --installed
peer chaincode list --instantiated -C mychannel

package

将打包链码为可部署的结构

peer chaincode package -i 实例化策略 -l 编写链码所使用的语言 -n 链码名称 -p 链码的本地路径 -s 创建一个用于部署链码的标准结构 -S 对用于部署链码的标准结构使用本地MSP签名 -v 链码版本 -o Orderer节点主机:端口
#全局变量
--tls 是否使用TLS加密 --cafile CA证书路径 --certfile X509公钥文件路径
#例子
peer chaincode package ccpack.out -n mycc -p github.com/hyperledger/fabric/examples/chaincode/go/chaincode_example02 -v 1.1 -s -S

query

调用链码功能对链码数据进行查询,不写入区块

peer chaincode query -C 通道ID -n 链码名称 -c 参数 -x 如果成功查询,则输出16进制结果
#全局变量
--tls 是否使用TLS加密 --cafile CA证书路径 --certfile X509公钥文件路径 -o Orderer节点主机:端口
#例子
peer chaincode query -C mychannel -n mycc -c '{"Args":["query","a"]}'

signpackage

对已打包的链码进行签名

peer chaincode signpackage
#全局变量
--tls 是否使用TLS加密 --cafile CA证书路径 --certfile X509公钥文件路径 -o Orderer节点主机:端口
#例子
peer chaincode signpackage ccwith1sig.pak ccwith2sig.pak

upgrade

更新一个存在的链码.命令与实例化链码相似。

 peer chaincode upgrade -C 通道ID -n 链码名称 -p 链码的本地路径 -P 链码的实例化策略 -v 链码的版本 -E 指定对该用户链码进行背书的系统链码 -V 指定对该用户链码进行验证的系统链码
#全局变量
--tls 是否使用TLS加密 --cafile CA证书路径 --certfile X509公钥文件路径 -o Orderer节点主机:端口
#例子
peer chaincode upgrade -o orderer.example.com:7050 --tls --cafile $ORDERER_CA -C mychannel -n mycc -v 1.2 -c '{"Args":["init","a","100","b","200","c","300"]}' -P "AND ('Org1MSP.peer','Org2MSP.peer')"

Peer version

打印当前Peer服务器的版本

peer version

configtxgen

该命令允许用户创建与检查通道配置信息

-asOrg 根据组织名称生成配置信息
-channelCreateTxBaseProfile
-channeID 使用配置文件中的通道ID
-configPath 指定配置文件的路径
-inspectBlock 打印具体路径下的区块的配置信息
-inspectChannelCreateTx 打印具体路径下的Transaction的配置信息
-outputAnchorPeersUpdate 创建一个用于更新锚节点的配置信息
-outputBlock 在指定的路径下生成创世区块
-outputCreateChannelTx 在指定的路径下生成创建通道的配置文件
-printOrg 以JSON的格式打印组织的信息
-profile 从configtx.yaml文件中生成profile 默认为``SampleInsecureSolo``
-version 打印版本信息

例子

#生成创世区块
configtxgen -outputBlock genesis_block.pb -profile SampleSingleMSPSoloV1_1 -channelID orderer-system-channel
#生成创建通道配置文件
configtxgen -outputCreateChannelTx create_chan_tx.pb -profile SampleSingleMSPChannelV1_1 -channelID application-channel-1
#查看创世区块信息
configtxgen -inspectBlock genesis_block.pb
#查看创建通道配置信息
configtxgen -inspectChannelCreateTx create_chan_tx.pb
#打印组织信息
configtxgen -printOrg Org1
#生成锚节点配置文件
configtxgen -outputAnchorPeersUpdate anchor_peer_tx.pb -profile SampleSingleMSPChannelV1_1 -asOrg Org1

configtxlator

通常用于转换protobufJSON格式的文件,protobuf一般为后缀为.pb的文件,由configtxgen生成

================start================
configtxlator start
--hostname="0.0.0.0"
--port=7059
--CORS=CORS
#启动configtxlator REST 服务
================start================
================proto_encode================
#转换``JSON``格式文件到``protobuf``格式
configtxlator proto_encode
--type=TYPE #``protobuf``格式的文件的类型,如'common.Config'
--input=/dev/stdin #包含'JSON'文件的地址
--output=/dev/stdout #输出地址
================proto_encode================
================proto_decode================
#转换``protobuf``格式到``JSON``格式文件
configtxlator proto_encode
--type=TYPE
--input=/dev/stdin
--output=/dev/stdout
================proto_decode================
================compute_update================
================version================
configtxlator version
#打印版本信息

cryptogen

用于生成Fabric中的密钥,用于测试环境下,生产环境下不使用

============generate====================
cryptogen generate
--output="crypto-config" 将文件生成到crypto-config文件夹下
--config=CONFIG 使用模板配置
============generate====================
============showtemplate====================
cryptogen showtemplate
#显示模板配置
============showtemplate====================
============extend====================
cryptogen extend
扩展已存在的网络
--output="crypto-config" 将文件生成到crypto-config文件夹下
--config=CONFIG 使用模板配置
============extend====================
============version====================
cryptogen version
#打印版本信息
============version====================

参考文档:https://hyperledger-fabric.readthedocs.io/en/release-1.4/command_ref.html

Hyperledger Fabric 命令整理的更多相关文章

  1. Hyperledger Fabric CA的命令行用法

    介绍Hyperledger Fabric CA的命令行方式简单用法 Hyperledger Fabric CA由server和client两部分组成. 设置两个环境变量 export FABRIC_C ...

  2. Hyperledger Fabric 常用命令

    Peer常用命令: #peer chaincode --help #peer channel list --help --logging-level <string> #<strin ...

  3. hyperledger fabric 架设命令

    单节点架设 Order 网络: cd ~/go/src/github.com/hyperledger/fabric/examples/e2e_cli/ rm -rf channel-artifacts ...

  4. Hyperledger Fabric 1.0 从零开始(一)——吐槽

    在HyperLedger/Fabric发布0.6的时候,公司就已经安排了一个团队研究这一块,后来也请IBM的专家组过来培训了一批人,不幸的是,这批人后来全走了,然后没过多久1.0就发布了.自从2017 ...

  5. HyperLedger Fabric 1.1 手动部署单机单节点

    手动部署单机单节点 之前发布过官方的e2e部署方案,由于环境或是访问权限等各种问题,还是有相当一部分码友无法成功跑起来,故此,本章将来一次纯手动操作的集群部署. 主要需要的步骤如下: 1:环境整理 2 ...

  6. hyperledger fabric部署总结

    之前在有道云笔记上分享过,但想想还是搬到这里来吧,以后统一方便整理自己的知识进入正题.... 之前在调研 hyperledger fabric,其实部署说明官网都有,只是东西都是国外的照着操作也会遇到 ...

  7. Hyperledger Fabric 1.0 从零开始(一)

    在HyperLedger/Fabric发布0.6的时候,公司就已经安排了一个团队研究这一块,后来也请IBM的专家组过来培训了一批人,不幸的是,这批人后来全走了,然后1.0就发布了.自从2017年7月H ...

  8. Hyperledger Fabric 1.2 --- Chaincode Operator 解读和测试(一)

    前言 本文主要目的是用于整理Hyperledger  Fabric中关于chaincode 管理和操作的内容,作者以release-1.2为范本进行讲解. 主要参考链接: https://hyperl ...

  9. (一)Hyperledger Fabric 1.1安装部署-基础环境搭建

    在学习和开发hyperledger fabric的时候遇到了一些坑,现将自己的一些总结和心得整理如下,以期对大家有所帮助.本次使用的宿主机环境:ubuntu,版本:Ubuntu 16.04.3 LTS ...

随机推荐

  1. asp .net mvc 获得用户IP

    string strHostName = System.Net.Dns.GetHostName(); //clientIPAddress是一个数组,可能有多个数据 var clientIPAddres ...

  2. MIS的趋势必定是围绕机器取代人手,分工越来越细(小餐厅都支持微信自助点餐,结账时就打个折,相当于省了1、2个人手,SQL发明以后,程序员的工作更多了)

    最后,我还想简略的谈谈MIS及MIS快速开发工具的未来. MIS的趋势必定是围绕机器取代人手,分工越来越细.比如:现在有些小型的咖啡厅里的财务子系统就简单到不需要使用者有会计知识,相当于省了会计人手: ...

  3. 【推荐网站】下载国外网盘+强大的离线下载站—offcloud.com

    博主在网上浏览时看到一篇帖子,推荐了一个离线下载网站–offcloud.com,支持上传种子文件.磁力链和几十家网盘的直连下载,厉害了我的哥,这是个啥网站这么666.即使之前咱们写了几篇文章来自建下载 ...

  4. WPF Button控件模板

     <Window x:Class="ControlTemplateDemo.MainWindow"        xmlns="http://schemas.m ...

  5. 通通WPF随笔(4)——通通手写输入法(基于Tablet pc实现)

    原文:通通WPF随笔(4)--通通手写输入法(基于Tablet pc实现) 从我在博客园写第一篇博客到现在已经有1年半了,我的第一篇博客写的就是手写识别,当时,客户需求在应用中加入手写输入功能,由于第 ...

  6. C# Thread 参数

     Thread (ParameterizedThreadStart) 初始化 Thread 类的新实例,指定允许对象在线程启动时传递给线程的委托.   Thread (ThreadStart) 初 ...

  7. 读取spring工程中resource的文件

    Resource resource = new ClassPathResource("data.json"); // 读文件到字符串 String fileContent = Fi ...

  8. 深入理解Amazon Alexa Skill(三)

    本节来讨论Alexa Skill中涉及到的授权问题. Alexa内功能的授权 Alexa会发给skill用户的token,然后skill代码使用这个token来访问Web API访问用户的Alexa内 ...

  9. 图像滤镜艺术--Toaster滤镜

    原文:图像滤镜艺术--Toaster滤镜     根据Instagram CEO的说法,Toaster滤镜是Instagram所有滤镜中最复杂的滤镜,这个滤镜给人一种新奇的红色烘烤感,很能让人联想起这 ...

  10. 一种基于Qt的可伸缩的全异步C/S架构服务器实现(一) 综述

    本文向大家介绍一种基于Qt的伸缩TCP服务实现.该实现针对C/S客户端-服务集群应用需求而搭建.连接监听.数据传输.数据处理均在独立的线程池中进行,根据特定任务不同,可安排负责监听.传输.处理的线程数 ...