当前位置: 首页 > 编程日记 > 正文

超级账本(Hyperledger Fabric)源码分析之一:总览

链客,专为开发者而生,有问必答!

此文章来自区块链技术社区,未经允许拒绝转载。

在这里插入图片描述

一、编译

1、环境准备

需要提前在linux或者mac机器上安装如下软件

1)Go,注意设置好gopath(笔者安装的是go1.8.3,对应的源码是v1.0.0这个tag,版本不对可能会出现编译不过或者运行出现问题)

2)Docker

3)一些依赖包(笔者当时没有装特殊的依赖包,所以这里不写了)

2、源码下载

首先先创建源码目录(注意这里必须是gopath下的这个目录,否则编译不过)

$ mkdir -p $GOPATH/src/github.com/hyperledger
$ cd $GOPATH/src/github.com/hyperledger

然后在该目录下复制仓库
$ git clone http://gerrit.hyperledger.org/r/fabric

笔者用的是v1.0.0的tag所以还需要

$ git checkout v1.0.0

3、编译

在源码目录中make

不过这样要求比较高,耗时比较长,会从网上下载一些docker镜像等等,读者如果嫌费时间或者由于网络原因搞不定,可以一个一个make

比如make native是编译一些bin比如order,peer等

而make order和make peer是编译两个关键程序

由于编译不是本文的重点所以简单提一下,如果有疑问欢迎给笔者留言交流

二、运行

自己配置联盟比较麻烦,比较建议是下载一个开源项目使用docker运行,以下是简单的方式

1、环境要求:

安装docker-compose

2、下载开源项目

$ git clone https://github.com/yeasy/docker-compose-files
$ cd docker-compose-files/hyperledger_fabric/v1.0.0

3、下载镜像

$ sudo bash scripts/ download_images.sh

4、启动

$ make start

后面的具体方式可以看Makefile,有运行、停止、初始化、测试链码等命令

三、架构

联盟链的概念比较多,从比特币转过来的同学可能刚开始会晕(因为我当时研究的时候看各种文章就很晕),所以我这里尽量把我的理解路径写出来

1、主程序

联盟链真正运行时只有两个主程序

1)peer,这个程序是参与实体的运行终端,也是命令行的终端(客户端),可以理解为比特币中的主程序。

2)order,一个排序服务,类比到比特币,暂时简单理解为主程序中的挖矿部分,因为联盟链把这部分功能单独隔离了出来。随着代码的深入了解,可以发掘其其他功能。

2、讲解模型

其中order服务是一个单独的服务,可以理解为一个专门各个组织公认的权威服务器(也可以是服务集群),主要用来对交易进行排序,然后生成区块(挖矿)

Org代表组织,讲解的模型中有两个组织,org1和org2,可以对应的是清华大学和北京大学

而peer一般代表的是组织内的子部门,比如org1.peer1代表清华大学的计算机学院,org2.peer2代表北京大学的计算机学院。

3、启动命令行

对应上图中的讲解模型每一个节点中的运行的命令行如下

1)order服务:order start

2)org1.peer1 : peer node start

3)org2.peer1 : peer node start

4)org1.peer2:peer node start

5)org2.peer2:peer node start

这里除了order运行是order start以外其他的全部是peer node start,那怎么区分他们的功能呢?

答案是通过msp和tls两个目录(这个后续再继续讲)

在各个节点运行过后,网络是这样的

也就是网络其实还没有互联起来

4、网络互联

要完成网络需要三步

1)创建通道

创建通道,可以单独在一个机器上运行

peer channel create \
-o orderer.example.com:7050 \
-c testchannel\
-f ./ testchannel.tx
ps:为了简单,这里省略了一些证书信息的配置(后文会讲解)

其中当前需要理解的参数是-o orderer.example.com:7050 代表了order的url,-c testchannel代表了通道的名字

这个命令其实就是通过连接到orderer.example.com:7050服务上,让服务器增加了一个通道的配置(配置文件是testchannel.tx),这个配置中包括了一些信息,比如证书信息,机构信息,以及一些权限设置等等。然后order会返回一个testchannel.block的文件(也是一些配置信息),加入通道时候会用到。

这一步并没有构建网络,网络模型依然如下

只是order服务中多了一个叫testchannel的通道

2)加入通道

命令为

CORE_PEER_ADDRESS=peer1.org1.example.com:7051 \
peer channel join \
-b testchannel.block
ps:这里省略了msp配置的信息

主要参数列出来

1、CORE_PEER_ADDRESS表明要加入通道的地址(因为实际操作时候是用的cli在另外的机器上操作要加入通道的peer)

2、testchannel.block 创建通道时候的返回文件

该命令执行完以后,网络模型变成了

可以看到org1的peer1和order连接陈功了,依次执行

CORE_PEER_ADDRESS=peer2.org1.example.com:7051 \
peer channel join \
-b testchannel.block

CORE_PEER_ADDRESS=peer1.org2.example.com:7051 \
peer channel join \
-b testchannel.block

CORE_PEER_ADDRESS=peer2.org2.example.com:7051 \
peer channel join \
-b testchannel.block

最后网络模型变成了

3)设置锚节点

各个节点都加入网络后,细心的读者可能会发现,和我们要达到的网络模型还少了几条线,也就是各个节点的互通线没有连接。而这个的完成需要gossip协议,而gossip协议是一个节点相互发现的协议,其中有一项就是需要一些锚点,fabric中一般每一个组织一到多个锚点。这个概念在讲解gossip协议的时候会进一步说明,在这里就只需要知道锚点的设置是为了网络互通就可以了,实在要理解,暂时理解为p2p协议中的初始域名服务器。命令如下:

peer channel update \
-o orderer.example.com:7050 \
-c testchannel \
-f ./Org1MSPanchors.tx
其中-c代表了通道名称,-f表示了锚点信息(里边会包含锚点的url比如peer1)-o指定了order节点。

在org1和org2中中分别生成锚点配置文件,然后执行以上命令就能把锚点信息更新到通道的配置中,这样各个节点就可以通过从order中更新配置,知道锚点,然后通过gossip协议进行全网互联,互联后网络模型如下

相关文章:

建模与设计01

转载于:https://www.cnblogs.com/invisible2/p/9016732.html

Bzoj2110--Wc2011Xor

考虑如果我们已经到达了终点,那么从终点出发显然可以异或上图中任何地方一个环的异或值后再回到终点,那么我们显然可以在到达终点后根据环的异或值调整自己 所以我们可以先处理出环上的异或值,我的做法是先做一颗生成树,然后dfs确…

usb打印机命令_Hyper-V与你的虚拟机共享设备、USB设备

仅适用于 Windows 虚拟机。增强会话模式可通过 RDP(远程桌面协议)将 Hyper-V 与虚拟机连接起来。 这不仅会改善你的整体虚拟机查看体验,而且使用 RDP 连接还可以使虚拟机与你的计算机共享设备。 由于 RDP 在 Windows 10 中默认打开,所以与 Windows 虚拟机…

以太坊源码分析之随心笔记

链客,专为开发者而生,有问必答! 此文章来自区块链技术社区,未经允许拒绝转载。 以太坊索引 table.go 定期随机选取一些节点找他们要他们的节点,放到本地,也就是一个随机找节点的table 里头的bucket 和 no…

ACM_求N^N的前5位数和后5位数(数论)

NNNNN Time Limit: 2000/1000ms (Java/Others) Problem Description: 对于整数N&#xff0c;求N^N的前5位和后5位&#xff08;1057题加强版) Input: 多组测试数据&#xff0c;每组测试数据输入为一个整数n&#xff08;6 < n < 10^9&#xff09;&#xff0c;n为0时结束。 …

ASP.NET MVC WebApi 返回数据类型序列化控制(json,xml)

我们都知道在使用WebApi的时候Controller会自动将Action的返回值自动进行各种序列化处理&#xff08;序列化为json&#xff0c;xml等&#xff09;&#xff0c;但是如果Controller的自动序列化后的结果不是我们想要的该怎么办呢&#xff1f;其实在MVC中有一个GlobalConfiguratio…

ai为什么要栅格化_三大优势告诉你,为什么一定要加盟AI定制家居

随着90后、00后逐渐成为社会的主力&#xff0c;他们也进入到了住房和家居市场&#xff0c;成为消费的主力军。和以前的消费者不同&#xff0c;生活条件更为优越的他们有能力&#xff0c;有想法追求更好的生活和居住环境&#xff0c;于是定制家居市场在这样的市场条件下蓬勃发展…

当区块链遇到零知识证明

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 什么是零知识证明 零知识证明的官方定义是能够在不向验证者任何有用的信息的情况下&#xff0c;使验证者相信某个论断是正确的。这个定义有点抽象&a…

从条纹边框的实现谈盒子模型(转)

类似下面这个图形&#xff0c;只使用一个标签&#xff0c;可以有多少种实现方式&#xff1a; 假设我们的单标签为 div: 1<div></div>定义如下通用 CSS: 12345div{position:relative;width: 180px;height: 180px;}这一题主要考查的是盒子模型 Box Model 与 背景 bac…

python表格筛选打印_按行名进行表格筛选:awkpythonR

引入Excel确实很强大。用Excel查找一行很容易&#xff0c;同样的事情1000次就很复杂。批量查询的需求应运而生~实验狗确实需要各种帮助&#xff0c;不然就傻傻复制啦~1.awk读取多个文件awk BEGIN{OFSFS"\t"}ARGIND1{print $0, $1;}ARGIND2{} file1 file21)awk初步提取…

SVG和canvas

1、SVG实现的圆环旋转效果 参考&#xff1a;http://www.softwhy.com/article-6472-1.html 2、SVG中的图形可以通过 transform"matrix(0,-1,1,0,0,440)"进行旋转。 3、svg代码可以单独放在一个后缀名为 .svg 的文件中保存起来。这个文件就是矢量图片文件。 这点用来制…

用零知识证明解决投票安全

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 背景 我们经常会遇到需要给别人投票的情况&#xff0c;比如有些公司会组织员工给领导做反向打分&#xff0c;但是往往员工都不敢“真心实意”的打分…

gitLab创建自己的私有库

一.创建私有库的流程简介 创建一个项目,留着后面的流程3制作私有库在可以创建私有库的地方创建一个code repository, code repository是代码仓库,我们把代码上传到这个仓库。在可以创建私有库的地方创建一个spec repository, spec repository是配置仓库,所有的配置按照包名、版…

AngularJS安装配置与基础概要整理(上)

以前整理的&#xff0c;可供参考。 安装&#xff1a; 1.首先要安装node.js和它的npm包管理系统。&#xff08;nodejs相关待整理&#xff09; 2.安装grunt .grunt是一个基于任务的Javascript工程命令行构建工具。 在dos窗口输入&#xff1a;npm install grunt-cli -g 具体模块安…

通风与防排烟工程电子书_菠菜关于防排烟系统使用软接头工程量计算注意及定额选用建议...

前言&#xff1a;前几日分享《工程建设标准强制性条文》关于安装专业相关内容&#xff0c;其余规范部分&#xff0c;建议大家自行查看&#xff0c;不再继续分享。今日继续分享《建筑防烟排烟系统技术标准》相关内容依据1&#xff1a;2.1 设于排风兼排烟系统上的软接管必须为不燃…

超级账本(Hyperledger Fabric)之权限管理浅析

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 超级账本&#xff08;Hyperledger Fabric&#xff09;之权限管理浅析 超级账本是联盟链的代表&#xff0c;而其相对于共链&#xff08;例如比特币&a…

Java通过JDBC连接MySQL数据库

代码描述&#xff1a;把前台获取的字段作为查询条件&#xff0c;返回符合条件的记录。 1 package com.imooc.dao;2 3 import java.sql.Connection;4 import java.sql.DriverManager;5 import java.sql.PreparedStatement;6 import java.sql.ResultSet;7 import java.sql.SQLExc…

关于C#调用非托管DLL,报“内存已损坏的”坑,坑,坑

因客户需求&#xff0c;与第三方对接&#xff0c;调用非托管DLL&#xff0c;之前正常对接的程序&#xff0c;却总是报“内存已损坏的异常”&#xff0c;程序进程直接死掉&#xff0c;折腾到这个点&#xff08;2018-05-11 00:26&#xff09;&#xff0c;终于尘埃落定,直接上程序…

python会不会出现内存泄露_Python内存泄漏和内存溢出的解决方案

一、内存泄漏像Java程序一样&#xff0c;虽然Python本身也有垃圾回收的功能&#xff0c;但是同样也会产生内存泄漏的问题。对于一个用 python 实现的&#xff0c;长期运行的后台服务进程来说&#xff0c;如果内存持续增长&#xff0c;那么很可能是有了“内存泄露”。1、内存泄露…

以太坊发展历史回顾

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 以太坊历史 最近历史记录&#xff0c;请查看Taylor Gerring博客发帖。 诞生 2013年末Vitalik Buterin第一次描述了以太坊&#xff0c;作为他研究比…

医学图像分类_TauMed:医学诊断领域中的图像分类测试数据扩增

南京大学智能软件工程实验室iselab.cn摘要&#xff1a;深度学习在医学分类方面取得了长足的进步。但是&#xff0c;在许多现实的环境中&#xff0c;用于训练和测试的数据不足且不平衡&#xff0c;深度学习模型将很容易过度拟合且泛化能力很差。并且由于医院和患者的状况并不总是…

仲兆鹏 160809329 第5次

---恢复内容开始--- 第一题 #include<stdio.h>//输入三个数有小到大排序 int main() {int a;int b;int c;printf("输入三个整数:");scanf("%d %d %d",&a,&b,&c);if(a>c) { ta; ac; ct; } if(b>c) { tb…

promise实现多个请求并行串行执行

早上查资料&#xff0c;偶然发现这个话题&#xff0c;发现自己并不会&#xff0c;于是乎&#xff0c;下来研究了一下。 想想之前我们用jquery写请求的时候&#xff0c;要实现请求的串行执行&#xff0c;我们可能是这么做的。 $.ajax({url: ,data: ,success: function (data) {$…

人工智能和区块链的融合

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 AI与区块链结合&#xff0c;可能性有多大&#xff1f; 人工智能和区块链是促进各行业创新和转型的主要技术&#xff0c;对这一点各行业已达成共识。…

AngularJS学习笔记(3)——通过Ajax获取JSON数据

通过Ajax获取JSON数据 以我之前写的与用户交互的动态清单列表为例&#xff0c;使用JSON前todo.html代码如下&#xff1a; <!DOCTYPE html> <html ng-app"todoApp"> <head> <meta charset"UTF-8"> <title>TO DO List</tit…

python爬取哔哩哔哩视频_荐爬取哔哩哔哩中的cosplay小视频

爬取哔哩哔哩小视频前言&#xff1a;想必大家都对小视频感兴趣吧&#xff0c;今天的爬虫的内容为将哔哩哔哩中的视频下载到本地&#xff0c;今天爬取的网站为URL : https://vc.bilibili.com/p/eden/all#/?tab%E5%BE%A1%E5%AE%85%E6%96%87%E5%8C%96&tagCOSPLAY1. 分析站点a…

区块链双语术语大全

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 这是一个简单而又全面的Blockchain词汇表&#xff0c;用于令人印象深刻的blockchain语言世界。 51% Attack&#xff08;51%攻击&#xff09; 当一…

SQL SERVER的锁机制(三)——概述(锁与事务隔离级别)

五、锁与事务隔离级别 事务隔离级别简单的说&#xff0c;就是当激活事务时&#xff0c;控制事务内因SQL语句产生的锁定需要保留多入&#xff0c;影响范围多大&#xff0c;以防止多人访问时&#xff0c;在事务内发生数据查询的错误。设置事务隔离级别将影响整条连接。 SQL Serve…

开源造轮子:一个简洁,高效,轻量级,酷炫的不要不要的canvas粒子运动插件库...

一&#xff1a;开篇 哈哈哈&#xff0c;感谢标题党的莅临~ 虽然标题有点夸张的感觉&#xff0c;但实际上&#xff0c;插件库确实是简洁&#xff0c;高效&#xff0c;轻量级&#xff0c;酷炫酷炫的咯。废话不多说&#xff0c;先来看个标配例子吧&#xff1a; &#xff08;codepe…

python启动appium服务_python下appium服务的自启动和关闭

最近想把前不久写的webUi框架改写成mobile_Ui,也就是 用于手机端的UI自动化框架&#xff0c;目前已经完成该框架的改写&#xff0c;记录其中一些问题&#xff0c;框架后续会单独写篇幅介绍遇到的第一个问题就是1、python怎么能够自动启动和自动关闭appium服务&#xff0c;这样每…