Hyperledger Fabric 实战(十二): Fabric 源码本地调试
借助开发网络调试 fabric 源码本地调试
准备工作
IDE Goland
Go 1.9.7
fabric-samples 模块 chaincode-docker-devmode
fabric 源码
步骤
添加本地域名
127.0.0.1 peer
127.0.0.1 orderer
用 ide 打开 $GOPATH 下的fabric源码目录
在源码目录下添加 dev-network
把 sampleconfig 下的所有文件复制到 dev-network
修改 core.yaml 中 fileSystemPath = fabric源码目录下dev-network/production/peer(绝对路径)
修改 orderer.yaml 中 Location = fabric源码目录下dev-network/production/orderer(绝对路径)
在 dev-network 新建 config,并复制 fabric-samples 模块 chaincode-docker-devmode下的 myc.tx 和 orderer.block
1,接着调试网络,用debug模式运行 order 下的 main.go 文件 并添加配置,绝对路径的地方相对修改,然后运行
Environment:
ORDERER_GENERAL_LISTENADDRESS=0.0.0.0
ORDERER_GENERAL_GENESISMETHOD=file
ORDERER_GENERAL_GENESISFILE=fabric源码目录下dev-network/config/orderer.block(绝对路径)
ORDERER_GENERAL_LOCALMSPID=DEFAULT
ORDERER_GENERAL_LOCALMSPDIR=fabric源码目录下dev-network/msp(绝对路径)
FABRIC_CFG_PATH=fabric源码目录下dev-network(绝对路径)
2,接着调试网络,用debug模式运行 peer 下的 main.go 文件 并添加配置,绝对路径的地方相对修改,然后运行
Program arguments:
node start --peer-chaincodedev=true -o 127.0.0.1:7050
Environment:
CORE_PEER_LOCALMSPID=DEFAULT
CORE_PEER_ID=peer
CORE_PEER_MSPCONFIGPATH=fabric源码目录下dev-network/msp(绝对路径)
CORE_PEER_ADDRESS=127.0.0.1:7051
FABRIC_CFG_PATH=fabric源码目录下/dev-network(绝对路径)
3,接着调试网络,用debug模式运行 peer 下的 main.go 文件 并添加配置,绝对路径的地方相对修改,然后运行
Program arguments:
channel create -c myc -f fabric源码目录下dev-network/config/myc.tx(绝对路径) -o 127.0.0.1:7050
Environment:
CORE_PEER_LOCALMSPID=DEFAULT
CORE_PEER_ID=cli
CORE_PEER_MSPCONFIGPATH=fabric源码目录下dev-network/msp(绝对路径)
CORE_PEER_ADDRESS=127.0.0.1:7051
FABRIC_CFG_PATH=fabric源码目录下/dev-network(绝对路径)
4,接着调试网络,用debug模式运行 peer 下的 main.go 文件 并添加配置,绝对路径的地方相对修改,然后运行
Program arguments:
channel join -b myc.block
Environment:
CORE_PEER_LOCALMSPID=DEFAULT
CORE_PEER_ID=cli
CORE_PEER_MSPCONFIGPATH=fabric源码目录下dev-network/msp(绝对路径)
CORE_PEER_ADDRESS=127.0.0.1:7051
FABRIC_CFG_PATH=fabric源码目录下/dev-network(绝对路径)
5,接着调试网络,用debug模式运行 peer 下的 main.go 文件 并添加配置,绝对路径的地方相对修改,然后运行
Program arguments:
chaincode install -p github.com/hyperledger/fabric/examples/chaincode/go/chaincode_example02 -n mycc -v 1.0
Environment:
CORE_PEER_LOCALMSPID=DEFAULT
CORE_PEER_ID=cli
CORE_PEER_MSPCONFIGPATH=fabric源码目录下dev-network/msp(绝对路径)
CORE_PEER_ADDRESS=127.0.0.1:7051
FABRIC_CFG_PATH=fabric源码目录下/dev-network(绝对路径)
6,打开终端
cd $GOPATH/src/github.com/hyperledger/fabric/examples/chaincode/go/chaincode_example02
编译chaincode
go build -o chaincode_example02 接着运行
CORE_PEER_ADDRESS=peer:7052 CORE_CHAINCODE_ID_NAME=mycc:1.0 ./chaincode_example02
7,接着调试网络,用debug模式运行 peer 下的 main.go 文件 并添加配置,绝对路径的地方相对修改,然后运行
星际文件系统(InterPlanetary File System,缩写IPFS)是一个旨在创建持久且分布式存储和共享文件的网络传输协议,它是一种内容可寻址的对等超媒体分发协议。在IPFS网络中的节点将构成一个分布式文件系统。
准备两台 centos7 虚拟机,设置并网络连通
192.168.1.210
192.168.1.211
到 https://github.com/ipfs/go-ipfs 下在安装包 https://www.fengshen157.com/ github.com/ipfs/go-ipfs/releases/tag/v0.4.18
go-ipfs_v0.4.18_linux-amd64.tar.gz
下载并安装密钥创建工具
go get -u github.com/Kubuxu/go-ipfs-swarm-key-gen/ipfs-swarm-key-gen
将在 $GOPATH/bin/ipfs-swarm-key-gen 和 go-ipfs_v0.www.michenggw.com 4.18_linux-amd64.tar.gz 复制到两台虚拟机里
两台虚拟机安装ipfs
解压
tar -zxvf go-ipfs_v0.4.18_linux-amd64.tar.gz
移动文件
cd go-ipfs && sudo mv ipfs /usr/local/bin/ipfs
初始化IPFS节点(无需在内网寻找相邻节点)
ipfs init
在 192.168.1.210 虚拟机里创建共享密钥,同一个IPFS私链内的所有节点必须共享同一个密钥才能加入。
创建密钥:
./ipfs-swarm-key-gen > /root/.ipfs/swarm.key
创建完密钥放在了自己的ipfs默认配置文件夹下面(~/.ipfs/)
并清除所有缺省启动节点
ipfs bootstrap rm all
在 192.168.1.211 里清除所有缺省启动节点
ipfs bootstrap rm all
将 192.168.1.210 创建的 /root/.ipfs/swarm.key 复制到 192.168.1.211 的 /root/.ipfs/ www.dasheng178.com swarm.key
在 192.168.1.211 添加 192.168.1.210 为默认节点
ipfs bootstrap add /ip4/192.168.1.210/tcp/4001/ipfs/QmRBWWrTwd7d1QCKEjcLdGgZAvSKtSNgZdQznzF58RBwZ2
两台虚拟机启动IPFS节点
ipfs daemon &
查看peer
ipfs swarm peers
输出日志,成功
/ip4/192.168.1.210/tcp/4001/ipfs/QmRBWWrTwd7d1QCKEjcLdGgZAvSKtSNgZdQznzF58RBwZ2
Hyperledger Fabric 实战(十二): Fabric 源码本地调试的更多相关文章
- Alink漫谈(二十二) :源码分析之聚类评估
Alink漫谈(二十二) :源码分析之聚类评估 目录 Alink漫谈(二十二) :源码分析之聚类评估 0x00 摘要 0x01 背景概念 1.1 什么是聚类 1.2 聚类分析的方法 1.3 聚类评估 ...
- Hyperledger Fabric 实战(十): Fabric node SDK 样例 - 投票DAPP
Fabric node SDK 样例 - 投票DAPP 参考 fabric-samples 下的 fabcar 加以实现 目录结构 . ├── app │ ├── controllers │ │ └─ ...
- Java并发编程原理与实战十二:深入理解volatile原理与使用
volatile:称之为轻量级锁,被volatile修饰的变量,在线程之间是可见的. 可见:一个线程修改了这个变量的值,在另一个线程中能够读取到这个修改后的值. synchronized除了线程之间互 ...
- 十二.jQuery源码解析之.eq().first().last().slice()
eq(index):将集合中的索引为index的元素提取出来. first():返回集合中的第一个元素. .last():防护集合中的最后一个元素. .slice(start[,end]):返回集合中 ...
- SpringBoot实战(十二)之集成kisso
关于kisso介绍,大家可以参考官方文档或者是我的博客:https://www.cnblogs.com/youcong/p/9794735.html 一.导入maven依赖 <project x ...
- Python核心技术与实战——十二|Python的比较与拷贝
我们在前面已经接触到了很多Python对象比较的例子,例如这样的 a = b = a == b 或者是将一个对象进行拷贝 l1 = [,,,,] l2 = l1 l3 = list(l1) 那么现在试 ...
- Netty实战十二之WebSocket
如果你有跟进Web技术的最新进展,你很可能就遇到过“实时Web”这个短语,这里并不是指所谓的硬实时服务质量(QoS),硬实时服务质量是保证计算结果将在指定的时间间隔内被递交.仅HTTP的请求/响应模式 ...
- Node.js实战(十二)之Stream
Stream 是一个抽象接口,Node 中有很多对象实现了这个接口.例如,对http 服务器发起请求的request 对象就是一个 Stream,还有stdout(标准输出). Node.js,Str ...
- kubernetes实战(十二):k8s使用helm持久化部署redmine集成openLDAP
1.基本概念 此次安装的有Jenkins.Gitlab.Redmine,我公司目前使用的是独立于k8s集群之外单独部署的Jenkins等服务,此文章会介绍三种服务基于k8s的部署方式,之后集成之前部署 ...
随机推荐
- eclipse中编译出现错误undefined reference to `_sbrk'
1. 在eclipse中使用gcc-arm-none-eabi-7-2017-q4-major-win32编译代码的时候出现了undefined reference to `_sbrk' e:/pro ...
- HBase第一章 安装 HMaster 主备
1.集群环境 Hadoop HA 集群规划 hadoop1 cluster1 nameNode HMaster hadoop2 cluster1 nameNodeStandby ZooKeeper ...
- 【Excel函数】如何在excle区分一列数字是否连续
需求:区分这批卡号,哪些在一个号段 数据源: 89860616090033685544898606160900336855518986061609003368556989860616090033685 ...
- java阻塞队列之ArrayBlockingQueue
在Java的java.util.concurrent包中定义了和多线程并发相关的操作,有许多好用的工具类,今天就来看下阻塞队列.阻塞队列很好的解决了多线程中数据的安全传输问题,其中最典型的例子就是客园 ...
- this指向问题(箭头函数没有this)
全局环境下,指向windows console.log(this.document === document); // true 函数上下文调用 function f1(){ return this; ...
- 180729-Quick-Task 动态脚本支持框架之任务动态加载
Quick-Task 动态脚本支持框架之任务动态加载 前面几篇博文分别介绍了整个项目的基本架构,使用说明,以及整体框架的设计与实现初稿,接下来则进入更细节的实现篇,将整个工程中核心实现捞出来,从为什么 ...
- JY播放器【蜻蜓FM电脑端,附带下载功能】
今天给大家带来一款神器----JY播放器.可以不用打开网页就在电脑端听蜻蜓FM的节目,而且可以直接下载,对于我这种强迫症患者来说真的是神器.我是真的不喜欢电脑任务栏上面密密麻麻. 目前已经支持平台(蜻 ...
- vps搭建个人网盘不二之选—kodexplorer介绍,包含安装步骤
之前给大家介绍过seafile.h5ai等网盘系统,今天给大家介绍下kodexplorer网盘系统.Kodexplorer,也叫芒果云.可道云.kodcloud,总之名字改了不少.但其本身作为一个网盘 ...
- Python基础知识-06-集合内存布尔False
python其他知识目录 1.判断一个字符串中是否有敏感字符? #str: m_str="我叫魔降风云变" if "魔" in m_str: #判断指定字符是否 ...
- USACO 3.3.1 Riding the Fences 骑马修栅栏(欧拉回路)
Description 农民John每年有很多栅栏要修理.他总是骑着马穿过每一个栅栏并修复它破损的地方. John是一个与其他农民一样懒的人.他讨厌骑马,因此从来不两次经过一个一个栅栏.你必须编一个程 ...