深度学习
超级账本(Hyperledger)所有项目代码托管在Gerrit和GitHub(只读,自动从Gerrit上同步)上。
目前,主要包括如下顶级项目:
·Fabric:包括Fabric、Fabric CA、Fabric SDK(包括Node.Js、Python和Java等语言)和fabric-api等,目标是区块链的基础核心平台,支持PBFT等新的共识机制,支持权限管理,最早由IBM和DAH发起;
·Sawtooth:包括arcade、core、dev-tools、validator、mktplace等。是Intel主要发起和贡献的区块链平台,支持全新的基于硬件芯片的共识机制Proof of Elapsed Time(PoET);
·Iroha:账本平台项目,基于C++实现,带有不少面向Web和Mobile的特性,主要由Soramitsu发起和贡献;
·Blockchain Explorer:提供Web操作界面,通过界面快速查看查询绑定区块链的状态(区块个数、交易历史)信息等,由DTCC、IBM、Intel等开发支持;
·Cello:提供区块链平台的部署和运行时管理功能。使用Cello,管理员可以轻松部署和管理多条区块链;应用开发者可以无需关心如何搭建和维护区块链,由IBM团队发起;
·Indy:提供基于分布式账本技术的数字身份管理机制,由Sovrin基金会发起;
·Composer:提供面向链码(链码的概念参见后面9.5节)开发的高级语言支持,自动生成链码等,由IBM团队发起并维护;
·Burrow:提供以太坊虚拟机的支持,实现支持高效交易的带权限的区块链平台,由Monax公司发起支持。
这些顶级项目相互协作,构成了完善的生态系统,如图8-3所示。
所有项目一般都需要经历提案(Proposal)、孵化(Incubation)、活跃(Active)、退出(Deprecated)、终结(End of Life)等5个生命周期。
任何希望加入到Hyperledger社区中的项目,必须首先由发起人编写提案。描述项目的目的、范围和开发计划等重要 信息,并由技术委员会来进行评审投票,评审通过则可以进入到社区内进行孵化。项目成熟后可以申请进入到活跃状态,发布正式的版本,最后从社区中退出并结 束。
8.3.1 Fabric项目
Fabric是最早加入到超级账本项目中的顶级项目,Fabric由IBM、DAH等企业于2015年底提交到社区。项目在GitHub上,地址为http://github.com/hyperledger/fabric 。
该项目的定位是面向企业的分布式账本平台,创新地引入了权限管理支持,设计上支持可插拔、可扩展,是首个面向联盟链场景的开源项目。
Fabric基于Go语言实现,目前提交次数已经超过5000次,核心代码超过8万行。
Fabric项目目前处于活跃状态,已发布1.0正式版本,同时包括Fabric CA、Fabric SDK等多个相关的子项目。
8.3.2 Sawtooth项目
Sawtooth项目由Intel等企业于2016年4月提交到社区。核心代码在GitHub上地址为http://github.com/hyperledger/sawtooth-core 。
该项目的定位也是分布式账本平台,基于Python语言实现,目前提交次数已经超过3000次。
Sawtooth项目利用Intel芯片的专属功能,实现了低功耗的Proof of Elasped Time(PoET)共识机制,并支持交易族(Transaction Family),方便用户使用它来快速开发应用。
8.3.3 Iroha项目
Iroha项目由Soramitsu等企业于2016年10月提交到社区。核心代码在GitHub上地址为http://github.com/hyperledger/iroha 。
该项目的定位是分布式账本平台框架,基于C++语言实现,目前提交次数已经超过2000次。
Iroha项目在设计上类似Fabric,同时提供了基于C++的区块链开发环境,并考虑了移动端和Web端的一些需求。
8.3.4 Blockchain Explorer项目
Blockchain Explorer项目由Intel、DTCC、IBM等企业于2016年8月提交到社区。核心代码在GitHub上,地址为http://github.com/hyperledger/blockchain-explorer 。
该项目的定位是区块链平台的浏览器,基于Node.js语言实现,提供Web操作界面。用户可以使用它来快速查看底层区块链平台的运行信息,如区块个数、交易情况、网络状况等。
8.3.5 Cello项目
Cello项目由笔者领导的IBM技术团队于2017年1月贡献到社区。GitHub上仓库地址为http://github.com/hyperledger/cello (核心代码)和http://github.com/hyperledger/cello-analytics (侧重数据分析)。
该项目的定位为区块链管理平台,同时提供区块链即服务(Blockchain-as-a-Service),实现区块链环境的快速部署,以及对区块链平台的运行时管理。使用Cello,可以让区块链应用人员专注到应用开发,而无需关心底层平台的管理和维护。
Cello的主要开发语言为Python和JavaScript等,底层支持包括裸机、虚拟机、容器云(包括Swarm、Kubernetes)等多种基础架构。
8.3.6 Indy项目
Indy项目由Sovrin基金会牵头进行开发,致力于打造一个基于区块链和分布式账本技术的数字中心管理平台。该平台支持去中心化,支持跨区块链和跨应用的操作,可实现全球化的身份管理。Indy项目于2017年3月底正式加入到超级账本项目。
该项目主要由Python语言开发,包括服务节点、客户端和通用库等,目前已有超过1000次提交。
8.3.7 Composer项目
Composer项目由IBM团队于2017年3月底贡献到社区,试图提供一个Hyperledger Fabric的开发辅助框架。使用Composer,开发人员可以使用JavaScript语言定义应用逻辑,再加上资源、参与者、交易等模型和访问规 则,生成Hyperledger Fabric支持的链码。
该项目主要由NodeJs语言开发,目前已有超过4000次提交。
8.3.8 Burrow项目
Burrow项目由Monax、Intel等企业于2017年4月提交到社区。核心代码在GitHub上地址为http://github.com/hyperledger/burrow 。
该项目的前身为eris-db,基于Go语言实现,目前提交次数已经超过1000次。
Burrow项目提供了支持以太坊虚拟机的智能合约区块链平台,并支持Proof-of-Stake共识机制和权限管理,可以提供快速的区块链交易。
来源:我是码农,转载请保留出处和链接!
本文链接:http://www.54manong.com/?id=935
微信号:qq444848023 QQ号:444848023
加入【我是码农】QQ群:864689844(加群验证:我是码农)
全站首页 | 数据结构 | 区块链| 大数据 | 机器学习 | 物联网和云计算 | 面试笔试
var cnzz_protocol = (("https:" == document.location.protocol) ? "https://" : "http://");document.write(unescape("%3Cspan id='cnzz_stat_icon_1276413723'%3E%3C/span%3E%3Cscript src='" + cnzz_protocol + "s23.cnzz.com/z_stat.php%3Fid%3D1276413723%26show%3Dpic1' type='text/javascript'%3E%3C/script%3E"));本站资源大部分来自互联网,版权归原作者所有!
评论专区