1.1 Fabric介绍
Fabric是数字事件(交易)的账簿,这个账簿由多个参与者共享,每个参与者都在系统中拥有权益。账簿只有在所有参与者达成共识的情况下才能够更新,并且信息一旦记录就永远不能修改。每个记录的事件都可以基于参与者的共识证明使用密码学进行验证。
交易是安全、私有和保密的。每个参与者使用身份证明向网络成员服务(membership service)注册以获取系统的访问权限。参与者使用不可追踪的导出证书生成交易,可以在网络中完全匿名。交易的内容使用由密钥导出的复杂函数进行加密,确保只有指定的参与者才能够看到内容,以保护商业交易的机密性。
1.2 使用Fabic的原因
早期的区块链技术能够实现一些功能,但是缺乏对特定行业需求的完整支持。为了满足现代市场的要求,fabric面向行业需求进行设计以适应多种行业特定的应用场景,并且在诸如伸缩性设计等方面比这个领域的先驱更进一步。Fabric使用了新的方法实现了授权网络、在多个区块链网络上的私有性和保密性。
以上做了简单的介绍,下面我们就开始搭建环境.
搭建环境目前我知道的有2种,有一种我没有搭建起来,这里只介绍一种方式吧
一、安装docker
执行代码如下:
curl -sSL https://get.daocloud.io/docker | sh
安装完成后,查看安装情况:
docker -v
Paste_Image.png
查看docker的安装目录:
whereis docker
Paste_Image.png
修改docker服务配置(/usr/bin/docker 文件)
vi /usr/bin/docker
把以下配置文件复制到服务配置文件里:
DOCKER_OPTS="$DOCKER_OPTS -H [tcp://0.0.0.0:2375](tcp://0.0.0.0:2375) -H [unix:///var/run/docker.sock](unix:///var/run/docker.sock) --api-cors-header='*'"
重启docker服务
sudo service docker restart
二、安装docker-compose
先安装python-pip,具体安装步奏如下:
1.首先安装epel扩展源:
sudo yum -y install epel-release
2.然后安装python-pip
sudo yum -y install python-pip
3.安装完成后,清除以下缓存 cache
sudo yum clean all
下面开始安装docker-compose
1.安装docker-compose:
curl -L https://get.daocloud.io/docker/compose/releases/download/1.9.0/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
2.查看安装情况:
Paste_Image.png配置以下docker镜像加速,目的是下载镜像速度更快:
curl -sSL https://get.daocloud.io/daotools/set_mirror.sh | sh -s [http://860eaa91.m.daocloud.io](http://860eaa91.m.daocloud.io/)
重启docker服务:
sudo service docker restart
三、下载镜像
docker pull hyperledger/fabric-peer:x86_64-0.6.1-preview \
&& docker pull hyperledger/fabric-membersrvc:x86_64-0.6.1-preview \
&& docker pull yeasy/blockchain-explorer:latest \
&& docker tag hyperledger/fabric-peer:x86_64-0.6.1-preview hyperledger/fabric-peer \
&& docker tag hyperledger/fabric-peer:x86_64-0.6.1-preview hyperledger/fabric-baseimage \
&& docker tag hyperledger/fabric-membersrvc:x86_64-0.6.1-preview hyperledger/fabric-membersrvc
图片:
Paste_Image.png四、安装git
1.安装依赖包:
sudo yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel gcc perl-ExtUtils-MakeMaker
2.下载git源码并解压安装:
$ wget https://github.com/git/git/archive/v2.3.0.zip
$ unzip v2.3.0.zip
$ cd git-2.3.0
3.编译安装:
make prefix=/usr/local/git all
sudo make prefix=/usr/local/git install
4.修改环境变量:
sudo vim /etc/profile
然后在文件的最后一行,添加下面的内容,然后保存退出。
export PATH=/usr/local/git/bin:$PATH
5.使用source命令立即保存:
source /etc/profile
6.查看版本
git version
Paste_Image.png
五、使用PBFT模式
PBFT 是经典的分布式一致性算法,也是 hyperledger 目前最推荐的算法,该算法至少需要 4 个节点。
1.首先,下载 Compose 模板文件。
git clone https://github.com/yeasy/docker-compose-files
2.进入 hyperledger/0.6/pbft 目录,查看包括若干模板文件
Paste_Image.png节点的情况我还没弄明白,后面还要继续研究,这里我就不乱说了
3.快速启动一个 4 个 PBFT 节点+1 个 CA 节点 + 1 个 Blockchain-explorer,并启用 CA 功能的集群:
docker-compose -f 4-peers-with-membersrvc-explorer.yml up
六、开始部署chaincode
集群启动后,进入一个 VP 节点。以 pbft 模式为例,节点名称为 pbft_vp0_1
docker exec -it pbft_vp0_1 bash
Paste_Image.png
部署example02
这里要先登录,如果是安全模式的话
账号保存在cat membersrvc/membersrvc.yaml
这里以内部账号jim 为例子
peer network login jim 6avZQLwcUe9b
peer chaincode deploy -p github.com/hyperledger/fabric/examples/chaincode/go/chaincode_example02 -c '{"Function":"init", "Args": ["a","100", "b", "200"]}'
Paste_Image.png
也可以再这里查看账号
Paste_Image.png记录到环境变量 CC_ID 中
CC_ID="ee5b24a1f17c356dd5f6e37307922e39ddba12e5d2e203ed93401d7d05eb0dd194fb9070549c5dc31eb63f4e654dbd5a1d86cbb30c48e3ab1812590cd0f78539"
查询 chaincode
peer chaincode query -u lukas -n ${CC_ID} -c '{"Function": "query", "Args": ["a"]}'
Paste_Image.png
网友评论