Fabric1.4基础搭建+票据示例

Fabric已经发布到1.4LTS版本,各个版本对比如下:

来自:超级账本解读 https://hyperledger.mochain.info/

Fabric v1.1版本主要的新特性包括: 

Fabric CA的CRL 

区块以及交易的事件推送 

增加了所有组建间的双向TLS通信 

Node.js Chaincode链码的支持 

Chaincode API新增了creator identity 

性能相对v1.0有了明显的提升

Fabric v1.2开始有了比较大的feature开始出现: 

Private Data Collections:这个特性不得不说在隐私保护上解决了不少项目的痛点,也减少了许多项目为了隐私保护在业务层做的复杂设计。 

Service Discovery:服务发现这个特性,使得客户端拥有了更多的灵活性和可操作性,可以动态感知整个Fabric网络的变化。 

Pluggable endorsement and validation:可插拔的背书及校验机制,采用了Go Plugin机制来实现,避免了之前需要重新编译源代码的操作,提升了灵活性。

Fabric v1.3中,同样增加了十分有用的feature:

基于Identity Mixer的MSP Implementation:基于零知识证明实现的身份的匿名和不可链接,这个feature替代了v0.6版本中的T-cert。 

key-level endorsement policies:更细粒度的背书策略,细化到具体的key-value,更加灵活,不仅限于一个链码程序作背书。 

新增Java Chaincode:至此,v1.3之后支持了Go、Node.js、Java 三种Chaincode,为开发者提供了更多的选择。 

Peer channel-based event services:Channel级别的事件订阅机制,早在v1.1版本中已经亮相了,在v1.3版本中正式发布,至此,旧的Event Hub正式宣告弃用。

Fabric v1.4是一个里程碑式的版本,是首个LTS的版本(Long Term Support的版本):

可操作性和可维护性的提升: 

开放日志级别设置的接口 

开放节点健康状态的检查接口 

开放节点数据指标的收集接口 

改进了Node SDK的编程模型,简化开发者的代码复杂度,使得SDK更加易用 

Private Data的增强: 

对于后续添加的允许访问节点能够获取之前的隐私数据 

添加客户端层面的隐私数据的权限控制,不需要添加链码逻辑。

这里作一个更新,新建Centos7.4的虚拟机环境。大致搭建过程如下。

实验环境

云主机:Centos 7.4 、CPU:4C、内存:16G,硬盘:200G。

相关前置软件安装

关闭Selinux,关闭防火墙等相关操作,相关操作网络上随处可查。

建议更新后再进行下列操作:

yum update

安装git、curl、pip

yum install git

yum install curl

yum -y install epel-release

yum install python-pip

pip install --upgrade pip

安装docker相关

yum install docker-ce

或者:yum install docker-ce.18.06.3.ce-3.el7  指定具体版本,可以先设置好yum 源(yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo)

pip install docker-compose(可能会失败,那就用以下的命令)

pip install docker-compose --ignore-installed requests

相关软件环境: 

安装完成后查看各个软件版本,如下图: 

注: 可能会碰到docker-compose报错:

File "/usr/lib/python2.7/site-packages/paramiko/ssh_gss.py", line 55, in <module>

GSS_EXCEPTIONS = (gssapi.GSSException,)

AttributeError: 'module' object has no attribute 'GSSException'

那么通过修改配置文件:/usr/lib/python2.7/site-packages/paramiko/ssh_gss.py来解决:

vi /usr/lib/python2.7/site-packages/paramiko/ssh_gss.py

53.55行修改如下解决:

53:import gssapi.error

55:GSS_EXCEPTIONS = (gssapi.error.GSSException,)

安装Golang、Node.js、npm

安装Golang 

如果单独去下载安装包麻烦的话,那么直接通过wget来下载解压,配置环境变量。

wget https://studygolang.com/dl/golang/go1.10.8.linux-amd64.tar.gz

tar -xvf go1.10.8.linux-amd64.tar.gz

配置环境变量。修改/etc/profile文件,路径根据下载安装路径来。

vim /etc/profile

添加

export GOROOT=/usr/go

export GOPATH=/usr/gopath

export PATH=$PATH:$GOROOT/bin:$GOPATH/bin

安装Node.js

wget https://npm.taobao.org/mirrors/node/v11.0.0/node-v11.0.0.tar.gz

tar -xvf node-v11.0.0.tar.gz

解压后进入Node文件夹:

yum install gcc gcc-c++

完成后gcc -v,这时候会发现gcc为4.8.5 建议更新:

wget http://ftp.gnu.org/gnu/gcc/gcc-7.3.0/gcc-7.3.0.tar.gz

更新完成后,解压gcc,并安装:

tar -xvf gcc-7.3.0.tar.gz

进入gcc-7.3.0目录执行:

./contrib/download_prerequisites

mkdir 一个新的目录

进入该目录 cd 目录

../configure --enable-checking=release --enable-languages=c,c++ --disable-multilib

make (请耐心等待,我这里大概等待了2个多小时。。。)

make install

建议重启后再进行之后的操作

重启后看到gcc版本为7.3.0 

安装Node.js

进入Node.js文件夹(这里可能有一个文件夹名的问题,建议修改node7.3.0文件夹名直接为node)

./configure

make (耐心等待)

make install

建议重启后再进行之后的操作

安装npm

npm install npm -g

完成上述操作后,查看各软件版本:

安装Fabric

首先下载Fabric源码,我们在go/src目录下新建文件夹。

mkdir -p github.com/hyperledger

进入该文件夹执行:

git clone https://github.com/hyperledger/fabric.git (耐心等待)

完成后进入 fabric/scripts文件夹,可以看到bootstrap.sh脚本,cat该脚本可以看到fabric版本为1.4.0:

执行bootstrap.sh脚本,自动进行fabric相关镜像的下载,耐心等待

./bootstrap.sh

镜像下载完成后如图: 

通过Fabric-samples提供的BYFN(build your first network)构建网络。

./byfn.sh -m generate -c jackychannel(自定义名字)

过程很快,完成后如图: 

启动网络:

./byfn.sh -m up -c jackychannel

启动后如图: 

完成后如图: 

这个时候出现4个peer节点,通过top命令可以清楚看到: 

注: 关闭命令:./byfn.sh -m down

启动网络服务后会启动排序服务节点、4个Peer节点,以及1个命令行容器cli。

搭建完成后功能测试

上述步骤完成后,可是去看下一些基本的操作和命令。

/usr/go/src/github.com/hyperledger/fabric/scripts/fabric-samples/first-network/channel-artifacts目录中,可称为创世区块目录(目录根据每个人的配置)

可以看到下列文件:

Org1MSPanchors.tx、Org2MSPanchors.tx,两个锚节点配置。 

channel.tx,生成通道配置文件。 

genesis.block,创世区块文件。

/usr/go/src/github.com/hyperledger/fabric/scripts/fabric-samples/first-network/crypto-config目录中,可称为证书目录(目录根据每个人的配置)

该目录存放生成排序服务节点和Peer节点的MSP证书文件,如图: 

使用docker命令查看运行中的镜像:

docker ps

结果如图: 

进入cli来进行一些简单的操作:

docker exec -it cli bash

切换到容器内做一个简单的查询:

peer chaincode query -C jackychannel(刚设置启动的名称) -n mycc -c '{"Args":["query","a"]}'

结果会看到90余额。

票据应用测试

在Fabric官网文档中有一个商业票据的例子,这里简单进行了测试。(停止Fabric网络服务后再进行以下操作。)

两个组织:MagnetoCorp、DigiBank, 

票据网络:PaperNet。

进入该目录启动基本网络:

/usr/go/src/github.com/hyperledger/fabric/scripts/fabric-samples/basic-network

./start.sh

启动完成后查看:docker ps 会出现4个运行中容器。

使用:docker network inspect net_basic命令查看docker网络: 

进入以下目录,启动:

cd commercial-paper/organization/magnetocorp/configuration/cli/

./monitordocker.sh net_basic

出现下图: 

另外开一个终端连接到服务器,在之前目录下,创建MagnetoCorp公司特定的docker容器。

cd commercial-paper/organization/magnetocorp/configuration/cli/

docker-compose -f docker-compose.yml up -d cliMagnetoCorp

再输入:docker ps 可以看到fabric-tools:3f078207c01a已加入网络中: 

MagnetoCorp 管理员通过fabric-tools:3f078207c01a来进行操作。

接下来看下智能合约: 

进入以下目录:

cd /usr/go/src/github.com/hyperledger/fabric/scripts/fabric-samples/commercial-paper/organization/magnetocorp/contract/lib

该目录下三个文件,其中papercontract.js为商业票据的智能合约。可以cat看下具体内容,这里暂不展开。

执行如下部署合约代码:

docker exec cliMagnetoCorp peer chaincode install -n papercontract -v 0 -p /opt/gopath/src/github.com/contract -l node

实例化智能合约:

docker exec cliMagnetoCorp peer chaincode instantiate -n papercontract -v 0 -l node -c '{"Args":["org.papernet.commercialpaper:instantiate"]}' -C mychannel -P "AND ('Org1MSP.member')"

输入如下: 

之前打开的终端中会有输出,也就是logsout容器的中的日志输出内容,具体如下: 

再次docker ps就可以看到:dev-peer0.org1.example.com-papercontract-0,说明此容器是peer0.org1.example.com节点启动的,且正在运行的papercontract链码版本为0。 

(由于突发事件,未完待续。。。)

参考文章: 

1.https://www.jianshu.com/p/cb032c42c909 

2.https://blog.csdn.net/ASN_forever/article/details/87859346

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,616评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,020评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,078评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,040评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,154评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,265评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,298评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,072评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,491评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,795评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,970评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,654评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,272评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,985评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,815评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,852评论 2 351

推荐阅读更多精彩内容