我很高興回答這個問題!簡短的回答是:是的,確實如此!php
我對大規模Hyperledger Fabric(Fabric)的性能提出了不少疑問。不少時候,人們已經完成了一些(或閱讀/據說過)性能測試(好比在他們的筆記本電腦或早期版本的Fabric上使用Caliper的早期版本),而且感受性能並非那麼好。前端
Fabric維護人員很容易認可,在Hyperledger Fabric v1.1.0發佈以前,性能並不高。Fabric的維護者在Fabric v0.6已經認識到,咱們須要採用新的架構,使平臺可以實現許多潛在的企業區塊鏈用例所要求的性能特徵。咱們對v1.0.0的目標是爲用戶提供新架構的功能版本。咱們不想陷入過早的優化。從那時起,咱們在性能改進方面投入了大量資金,從v1.1.0版本開始,一直持續到今天。java
在我主持的IBM博客上,我發起了一系列帖子,旨在提供有關Hyperledger Fabric的性能和規模的信息。我關於這個主題的最初博客文章開始概述了一些改進Hyperledger Fabric性能的最佳實踐,這些實踐是我從Fabric承認策略,負載平衡和orderer配置的實驗中收集到的。我最近的帖子解決了Fabric對擴展其通道架構能力的一種常見誤解。node
那麼,Hyperledger Fabric的性能會隨着頻道的增長而受到影響嗎?簡短的回答是:並不是我觀察到最新版本的Fabric v1.4.0和v1.4.1。我鼓勵你跳到我上面的兩個帖子瞭解詳細信息。python
實際上使人驚喜的另外一個有趣的發展是,針對Fabric訂購服務引入Raft共識已經在延遲方面取得了很大的改進,實際上容許人們將總體吞吐量推到新的高度,同時將延遲保持在可接受的水平。它還顯着下降了運行Kafka和Zookeeper的操做複雜性。android
儘管作出全面的陳述還爲時過早,但初始測試在吞吐量方面取得了使人矚目的進步,同時將延遲保持在一秒以內。程序員
Fabric社區繼續致力於性能的各個方面。咱們的下一個版本(v1.4.1-rc1如今可用於測試)將重點關注上面提到的Raft共識。下一個版本v2.0將包含一個狀態數據庫緩存,該緩存應該能夠在訪問狀態數據庫時實現總體性能提高。web
接下來,一旦緩存更新,咱們將努力釋放狀態數據庫上的鎖,以減小鎖爭用並實現更高的吞吐量。咱們正在從社區成員那裏得到很好的看法和建議,他們專一於Fabric的性能,並逐漸但願在今年的後續版本中利用這種學習。mongodb
做者:Chris Ferris,IBM傑出的工程師,IBM數字業務集團開放技術CTO。
======================================================================
分享一些比特幣、以太坊、EOS、Fabric等區塊鏈相關的交互式在線編程實戰教程:
- java比特幣開發教程,本課程面向初學者,內容即涵蓋比特幣的核心概念,例如區塊鏈存儲、去中心化共識機制、密鑰與腳本、交易與UTXO等,同時也詳細講解如何在Java代碼中集成比特幣支持功能,例如建立地址、管理錢包、構造裸交易等,是Java工程師不可多得的比特幣開發學習課程。
- php比特幣開發教程,本課程面向初學者,內容即涵蓋比特幣的核心概念,例如區塊鏈存儲、去中心化共識機制、密鑰與腳本、交易與UTXO等,同時也詳細講解如何在Php代碼中集成比特幣支持功能,例如建立地址、管理錢包、構造裸交易等,是Php工程師不可多得的比特幣開發學習課程。
- c#比特幣開發教程,本課程面向初學者,內容即涵蓋比特幣的核心概念,例如區塊鏈存儲、去中心化共識機制、密鑰與腳本、交易與UTXO等,同時也詳細講解如何在C#代碼中集成比特幣支持功能,例如建立地址、管理錢包、構造裸交易等,是C#工程師不可多得的比特幣開發學習課程。
- java以太坊開發教程,主要是針對java和android程序員進行區塊鏈以太坊開發的web3j詳解。
- python以太坊,主要是針對python工程師使用web3.py進行區塊鏈以太坊開發的詳解。
- php以太坊,主要是介紹使用php進行智能合約開發交互,進行帳號建立、交易、轉帳、代幣開發以及過濾器和交易等內容。
- 以太坊入門教程,主要介紹智能合約與dapp應用開發,適合入門。
- 以太坊開發進階教程,主要是介紹使用node.js、mongodb、區塊鏈、ipfs實現去中心化電商DApp實戰,適合進階。
- ERC721以太坊通證明戰,課程以一個數字藝術品創做與分享DApp的實戰開發爲主線,深刻講解以太坊非同質化通證的概念、標準與開發方案。內容包含ERC-721標準的自主實現,講解OpenZeppelin合約代碼庫二次開發,實戰項目採用Truffle,IPFS,實現了通證以及去中心化的通證交易所。
- C#以太坊,主要講解如何使用C#開發基於.Net的以太坊應用,包括帳戶管理、狀態與交易、智能合約開發與交互、過濾器和交易等。
- EOS入門教程,本課程幫助你快速入門EOS區塊鏈去中心化應用的開發,內容涵蓋EOS工具鏈、帳戶與錢包、發行代幣、智能合約開發與部署、使用代碼與智能合約交互等核心知識點,最後綜合運用各知識點完成一個便籤DApp的開發。
- 深刻淺出玩轉EOS錢包開發,本課程以手機EOS錢包的完整開發過程爲主線,深刻學習EOS區塊鏈應用開發,課程內容即涵蓋帳戶、計算資源、智能合約、動做與交易等EOS區塊鏈的核心概念,同時也講解如何使用eosjs和eosjs-ecc開發包訪問EOS區塊鏈,以及如何在React前端應用中集成對EOS區塊鏈的支持。課程內容深刻淺出,很是適合前端工程師深刻學習EOS區塊鏈應用開發。
- Hyperledger Fabric 區塊鏈開發詳解,本課程面向初學者,內容即包含Hyperledger Fabric的身份證書與MSP服務、權限策略、信道配置與啓動、鏈碼通訊接口等核心概念,也包含Fabric網絡設計、nodejs鏈碼與應用開發的操做實踐,是Nodejs工程師學習Fabric區塊鏈開發的最佳選擇。
- Hyperledger Fabric java 區塊鏈開發詳解,課程面向初學者,內容即包含Hyperledger Fabric的身份證書與MSP服務、權限策略、信道配置與啓動、鏈碼通訊接口等核心概念,也包含Fabric網絡設計、java鏈碼與應用開發的操做實踐,是java工程師學習Fabric區塊鏈開發的最佳選擇。
- tendermint區塊鏈開發詳解,本課程適合但願使用tendermint進行區塊鏈開發的工程師,課程內容即包括tendermint應用開發模型中的核心概念,例如ABCI接口、默克爾樹、多版本狀態庫等,也包括代幣發行等豐富的實操代碼,是go語言工程師快速入門區塊鏈開發的最佳選擇。
匯智網原創翻譯,轉載請標明出處。這裏是Hyperledger Fabric可否大規模運行?