月亮链 月亮链
Ctrl+D收藏月亮链
首页 > KuCoin > 正文

区块链:区块链的速度性能困境:“慢”得其所 “贵”在信任_ethical这么读

作者:

时间:1900/1/1 0:00:00

区块链为什么会这么慢?具体慢在哪里?

编者按:很多人抱怨说比特币转账速度慢过蜗牛,但其实慢是有原因的,下面由FISCO BCOS 首席架构师为你讲解为什么区块链转账这么慢?具体慢在哪里?能不能快一点?

举个例子

数钱,比如数一个亿(是不是好刺激~)

1、如果一个人数,慢,但好在专注,全力以赴,在可见的时间内可以数完。这叫单线程密集计算。

2、如果N个人一起数,每人平分,分头同时数,最后汇总总数,所用时间基本上是第一种情况的1/N,参与的人越多,所需时间就越少,TPS就越高。这叫并行计算和MapReduce。

3、如果N个人一起数,但由于这N个人互相不信任,得彼此盯着,首先抽签选一个人,这个人捡出一叠钱(比如一万块一叠)数一遍,打上封条,签名盖章,然后给另外几个人一起同时重新数一遍,数好的人都签名盖章,这叠钱才算点好了。然后再抽签换个人检出下一叠来数,如此循环。因为一个人数钱时别人只是盯着,而且一个人数完且打上封条和签名的一叠钱,其他人要重复数一遍再签名确认,那么可想而知,这种方式肯定是最慢的。这就叫区块链。

但换个角度,方式1,一个人数有可能会数错,这个人有可能生病或休假,导致没有人干活,更坏的结果是,这个人可能调换假币或者私藏一部分钱,报一个错的总数。

金证股份:金证股份在区块链技术领域有一定的研究:12月28日消息,近日金证股份表示,公司在区块链技术领域有一定的研究,金证区块链存证管理平台已发布,区块链智能底稿服务平台已完成,公司在持续研究其它应用场景。[2021/12/28 8:08:47]

方式2,N个人中会有一定比例数错,也可能其中一个人休假或者怠工,导致最终结果出不来,更可能因为人多手杂,出现部分人偷钱、换假钱、报假数……

方式3,很慢,但是很安全,因为所有人都会盯着全过程进行验算,所以肯定不会数错。如果其中有人掉线,可以换人捡出新的一叠钱继续数,工作不会中断。所有数过的钱上面都有封条和签名,不会被做手脚,万一出错了也可以找到责任人进行追责。这种情况下,资金安全是完全得到保障的,除非所有的参与者都串通一气了。该模式下,参与的人越多,资金安全性就越高。

所以,区块链方案致力追求的是,在缺乏互相信任的分布式网络环境下,实现交易的安全性、公允性,达成数据的高度一致性,防篡改、防作恶、可追溯,付出的代价之一就是性能。

最著名的比特币网络,平均每秒只能处理5~7笔交易,10分钟出1个块,达到交易的最终确定性需要6个块也就是1个小时,且出块过程相当损耗算力(POW挖矿)。号称“全球计算机”的以太坊,每秒能处理的交易数也仅是2位数的量级,十几秒出1个块。以太坊目前也是采用损耗算力的共识机制POW挖矿,会逐步迁移到POS共识机制。这两个网络在粉丝们爆炸性地进行交易时,可能会陷入拥堵状态,大量的交易发出后,一两天甚至更长的时间才会被打包确认。

区块链开发公司Blockchain Foundry私募融资1000万加元:3月8日消息,北美区块链开发公司Blockchain Foundry Inc. (CSE:BCFN)宣布,已经与某些机构投资者签订了证券购买协议,以私募方式发行29792595股普通股和认股权证,每股普通股和相关认股权证的购买价为0.3375加元,筹集的资金总额约为1000万加元。认股权证的行权价格为每股普通股0.45加元,可在发行日期五周年之前的任何时间行权。(GlobeNewsWire)[2021/3/8 18:24:21]

但在资金安全就是命的场景下,有些事情是“必须”的,所以,即使慢,还是会考虑选择区块链。

区块链为什么慢

分布式系统里有一个著名的理论叫CAP理论:2000年,Eric Brewer教授提出一个猜想:一致性、可用性和分区容错性三者,无法在分布式系统中被同时满足,并且最多只能满足其中两个。

CAP的大致解释

Consistency(一致性) :数据一致更新,所有数据变动都是同步的

Availability(可用性):好的响应性能

Partition tolerance(分区容错性): 可靠性

这个理论虽然有一些争议,但从工程实践中看,和光速理论一样,可以无限逼近极致但是难以突破。区块链系统能把一致性和可靠性做到极致,但是“好的响应性能”方面一直有点被人诟病。

解放军报:让区块链助力军事人力资源配置:解放军报融媒体今日刊文“让区块链助力军事人力资源配置”。文章表示,探索“区块链+军事人力资源配置”的应用新模式,能够充分向区块链借力,提升军事人力资源配置效能。利用区块链技术,构建不同层级人力资源部门之间局部去中心化的“联盟链”,从根本上破除因层级维护缺乏监督而影响数据可靠性的问题。此外,尤其是战时,区块链在实现军事人力资源精准配置上具有明显优势,一方面,基于链上各作战节点实时采集、更新的人力资源动态信息,能够精准测算战损比例、兵力需求,便于提前筹划人才预置、精准储备作战人才;另一方面,利用区块链智能合约技术,将兵力补充规则转换成链上智能合约代码,设置兵力补充响应优先级,从不同地域、不同专业、不同岗位,提出全时动态精准的多组合补充方案,对实施作战筹划具有重要参考价值。[2020/9/1]

我们面向的“联盟链”领域,因为在准入标准,系统架构、参与节点数、共识机制等方面都和公链不同,其性能表现远高于公有链,但是目前几个主流的区块链平台,在常规PC级服务器硬件上实测,TPS一般是在千级的样子,交易延迟一般在1秒到10秒这个级别。(听说TPS十几万级和百万级千万级区块链已经做出来了?好吧,期待)

笔者曾在大型互联网公司工作多年,在海量服务领域,面对C10K问题(concurrent 10000 connection,万级并发)已经有轻车熟路的解决方案,对一般的电商业务或内容浏览服务,普通pc级服务器单机达到几万TPS,且平均延时在500毫秒以内,飞一般的体验已经是常态,毕竟互联网产品卡一下说不定就会导致用户流失。对于快速增长的互联网项目,通过平行扩容、弹性扩容、立体扩容的方式,几乎能无底线、无上限地面对山呼海啸的海量流量。

南非区块链初创企业SunExchang完成300万美元融资:专注于可再生能源的南非区块链初创企业SunExchange宣布新完成了一笔300万美元的融资,投资方为南非亿万富翁Patrice Motsepe的非洲彩虹资本(African Rainbow Capital,ARC) 。

从2019年首轮融资至今,该公司共筹集了400万美元。(路透)[2020/6/9]

相比而言,区块链的性能比互联网服务慢,而且难以扩容,根因还是在其“用计算换信任”的设计思路上。

具体哪里慢呢?

从“古典”区块链的系统内部来看

1、为了安全防篡改防泄密可追溯,引入了加密算法来处理交易数据,增加了CPU计算开销,包括HASH、对称加密、椭圆曲线或RSA等算法的非对称加密、数据签名和验签、CA证书校验,甚至是目前还慢到令人发指的同态加密、零知识证明等。在数据格式上,区块链的数据结构本身包含了各种签名、HASH等交易外的校验性数据,数据打包解包、传输、校验等处理起来较为繁琐。

对比互联网服务,也会有数据加密和协议打包解包的步骤,但是越精简越好,优化到了极致,如无必要,绝不增加累赘的计算负担。

2、为了保证交易事务性,交易是串行进行的,而且是彻底的串行,先对交易排序,然后用单线程执行智能合约,以避免乱序执行导致的事务混乱、数据冲突等。即使在一个服务器有多核的CPU,操作系统支持多线程多进程,以及网络中有多个节点、多台服务器的前提下,所有交易也是有条不紊地、严格地按单线程在每台计算机上单核地进行运算,这个时候多核CPU其他的核可能完全是空闲的。

动态 | 泰国政府利用区块链技术简化外国游客增值税退税流程:从本月底开始,到泰国旅游的外国游客将可以通过一款区块链应用程序来申请退还购物产生的增值税(VAT),并可将资金直接发送至其信用卡或移动支付应用中。泰国政府除了通过引入区块链支付方式来降低有关部门的管理成本和申请人的文书工作外,还将退还增值税的上限从每名游客12000英镑提高至30000英镑。据悉,泰京银行(KTB)提供了用于增值税退税的技术解决方案。据此前消息,泰国财政部下属机构国产税厅(The Excise Department)总干事Patchara Anuntasilpa透露,随着泰国迈向4.0时代,国产税厅正计划利用数字平台和区块链技术来改善服务,以配合政府和财政部的政策,提升公共服务。(Ico Examiner)[2019/11/16]

而互联网服务则是能用多少服务器的多少个核,采用全异步处理、多进程、多线程、协程、缓存、优化IOWAIT等等,一定会把硬件计算能力跑满。

3、为了保证网络的整体可用性,区块链采用了P2P网络架构以及类似Gossip的传输模式,所有的区块和交易数据,都会无差别地向网络广播,接收到的节点继续接力传播,这种模式可以使数据尽可能地传达给网络中的所有人,即使这些人在不同的区域或子网里。代价是传输冗余度高,会占用较多的带宽,且传播的到达时间不确定,可能很快,也可能很慢(中转次数很多)。

对比互联网服务,除非出错重传,否则网络传输一定是最精简的,用有限的带宽来承载海量的数据,且传输路径会争取最优,点对点传输。

4、为了支持智能合约特性,类似以太坊等区块链解决方案,为了实现沙盒特性,保证运行环境的安全和屏蔽不一致性因素,其智能合约引擎要么是解释型的EVM,或者是采用docker封装的计算单元,智能合约核心引擎的启动速度,指令执行速度,都没有达到最高水平,消耗的内存资源也没有达到最优。

而用常规计算机语言如C++、JAVA、go、rust语言直接实现海量互联网服务,在这方面常常没有限制。

5、为了达到可容易校验防篡改的效果,除了第一条提到的,区块数据结构里携带数据较多之外,针对交易输入和输出,会采用类似merkle树、帕特里夏(Patricia )树等复杂的树状结构,通过层层计算得到数据证明,供后续流程快速校验。树的细节这里不展开,可以通过网络上的资料来学习其机制。

基本上,生成和维护这种树的过程是非常非常非常非常繁琐的,既占用CPU的计算量,又占用存储量,使用了树后,整体有效数据承载量(即客户端发起的交易数据和实际存储下来的最终数据对比)急剧下降到百分之几,极端情况下,可能接受了10m的交易数据后,在区块链磁盘上可能实际需要几百兆的数据维护开销),因为存储量的几何级数增加,对IO性能要求也会更高。

互联网服务因为基本不考虑分布式互验互信的问题,很少有使用这种树的证明结构,了不起算下MD5和HASH做为协议校验位。

6、为了达到全网一致性和公信力,在区块链中所有的区块和交易数据,都会通过共识机制框架驱动,在网络上广播出去,由所有的节点运行多步复杂的验算和表决,大多数节点认可的数据,才会落地确认。

在网络上增加新的节点,并不会增加系统容量和提升处理速度,这一点彻底颠覆了“性能不足硬件补”的常规互联网系统思维,其根因是区块链中所有节点都在做重复的验算以及生成自己的数据存储,并不复用其他节点数据,且节点计算能力参差不齐,甚至会使最终确认的速度变慢。

在区块链系统中增加节点,只会增加可容错性和网络的公信力,而不会增强性能表现,使得在同一个链中,平行扩展的可能性基本缺失了。

而互联网服务大多是无状态的,数据可缓存可复用,请求和返回之间的步骤相对简单,容易进行平行扩展,可以快速调度更多的资源参与服务,拥有无限的弹性。

7、因为区块数据结构和共识机制特性,导致交易到了区块链之后,会先排序,然后加入到区块里,以区块为单位,一小批一小批数据的进行共识确认,而不是收到一个交易立刻进行共识确认,比如:每个区块包含1000个交易,每3秒共识确认一次,这个时候交易有可能需要1~3秒的时间才能被确认。

更坏的情况是,交易一直在排队,而没有被打包进区块(因为队列拥堵),导致确认时延更长。这种交易时延一般远大于互联网服务500ms响应的标准。所以区块链其实并不适合直接用于追求快速响应的实时交易场景,行业通常说的“提高交易效率”是把最终清结算的时间都算在内的,比如把T+1长达一两天的对账或清计算时延,缩短到几十秒或几分钟,成为一个“准实时”的体验。

综上所述,区块链系统天生就背着几座大山,包括单机内部计算开销和存储较大,背着串行计算的原罪,网络结构复杂冗余度高,区块打包共识的节奏导致时延较长,而在可扩展性上又难以直接增加硬件来平行扩容,导致scale up和scale out两方面,都存在明显瓶颈。

Scale Out(等同scale horizontally):横向扩展,向外扩展,如:向原有系统添加一组独立的新机器,用更多的机器来增加服务容量

Scale Up(等同Scale vertically):纵向扩展,向上扩展,如向原有的机器添加CPU、内存,在机器内部增加处理能力

直面区块链的速度困境,FISCO BCOS的开发者发挥“愚公移山”的精神,努力优化。经过一段时间的努力,已经移山倒海,修出了一条又一条高速通道,使区块链找到了迈向极速时代的路子(详见下篇),这就是我们系列文章要深入解析的内容。

标签:区块链CALSCALECHA区块链运用的技术中不包括哪一项a共识算法ethical这么读SCALE价格durianchain

KuCoin热门资讯
数字人:数字人民币对公钱包增长率超过150% 应用场景逐渐增多_数字人民币存银行失败

移动支付网消息:4月2日,数字人民币第三批试点地区公布,新增11个城市。当前,很多人对数字人民币个人钱包比较关注,对公钱包表示“有些受伤”。其实,数字人民币对公钱包也在“飞速成长”.

1900/1/1 0:00:00
元宇宙:元宇宙与国家数据安全:构建生态化治理体系的挑战与趋势_METAWAR

文│复旦大学网络空间国际治理研究基地主任 沈逸2021 年 3 月,创建于 2004 年的游戏公司罗布乐思(Roblox)在招股概念书中引入完成于 30年前的小说《雪崩》(Snow Crash).

1900/1/1 0:00:00
SWAP:金色前哨 | Avalanche峰会黑客马拉松获奖者名单公布_DEX

Avalanche Summit 3月22日至27日在西拔牙巴塞罗那举行,在峰会期间的25-27日同时举行了由Encode Club举行的黑客马拉松活动.

1900/1/1 0:00:00
区块链:晚间必读5篇 | 本周需要了解的关于比特币的5件事_以太坊

1.Vitalik亲自告诉你:什么是以太坊及其优缺点加密KOL Naval近日在播客采访了以太坊创始人Vitalik,Vitalik在播客里回顾了以太坊的起源故事,并亲自解释了什么是以太坊.

1900/1/1 0:00:00
NFT:被盗风波带动AZUKI频频上涨?_AZU

近日,AZUKI交易量频频上涨,日交易量已多次超过BAYC,并且还吸引了NFT藏家dingaling、加密KOL神鱼等很多行业内大V争相入场.

1900/1/1 0:00:00
NFT:《时代》杂志推出首个NFT杂志 新闻机构入局NFT对媒体而言是好是坏?_NFTOPIA

事实上,NFT早在2014年就已经出现,只不过那时NFT还只是被一小部分人所知晓的小众技术。谁能想到,几年以后,在疫情背景下,以及随着Beeple那6930万美元的天价NFT作品的成功拍卖,NF.

1900/1/1 0:00:00