Hi 游客

更多精彩,请登录!

比特池塘 区块链前沿 正文

并不完美的区块链三个“天然缺陷”

123458446
129 0 0
区块链技术并不完美。6 a4 v8 t; C6 r& x5 P
事实上,任何新技术诞生之初都会存在“先天缺陷”。缺陷会随着技术进步而被完善,然后在新的技术背景下,再面临新的“缺陷”。
1 |, q* v( A  n* d' W. A( M% V比如飞机这个航空技术。1903年12月,莱特兄弟进行了人类历史上首次试飞,但是并不受美国政府重视,同时受限于材料,空气动力学,飞机发展也相当缓慢。直到两次世界大战,才推动了飞机在军事领域的应用。
* |+ y( H/ m8 A6 Q$ |# e5 O区块链技术发展也不会例外。
% W9 D0 U3 H) t4 ~; d时间回到2010年,彼时比特币刚满1周岁,由于核心代码漏洞,有人利用该漏洞凭空造出了1840亿个比特币。
2 t  u7 U% l6 D+ P8 I- E+ _庆幸的是,在社群努力下,迅速修复了这个漏洞。而比特币核心代码组的开发者们,也在夜以继日地为比特币核心代码库做贡献,以修补瑕疵,这才有了区块链行业的今天。
( w/ o2 a* ^9 n1 N0 H  `* o1 r& a我们总是会把区块链技术“完美化”,殊不知,在经济学家、密码学家、计算机科学家眼中,区块链技术还有很多需要改进的地方。8 x/ W) R2 p" i! H$ G; j$ @
例如《区块链核心技术开发与应用》就认为目前区块链技术在数学工具、博弈论、密码学、代码存在局限性的情况下,还有很大的改进空间。换言之区块链技术要想被大规模商用,还有很长的路要走。
2 q! s" r+ l$ |/ [! @+ `& S那么,目前的区块链还存在什么不完美的地方呢?& x  C* P" Q. K5 Z' L" c
" S/ b' ~. w" ^
1; s( a3 [1 Z( @- W" J
完美代码的错觉
5 J: m; a2 {' z如果将比特币网络系统比作一个大型软件,那么计算机技术与编程则为这项技术的落地提供了载体。: a0 W3 O- d6 H2 x0 d0 R: {+ w
但是目前编程语言却明显存在一些不完美之处。
! F% o. B: q  T) v  i9 L7 i首先,语言种类繁多,没有哪种语言能够“一统江湖”。不同项目使用完全不同的编程语言,屡见不鲜:# l% S2 o" u1 e1 c" ^' w9 k
(1)比特币与瑞波币使用了C++;(2)以太坊则使用了四种专用语言:Serpent(受 Python启发)、 Solidity(受 Javascript启发)、Mutan(受Go启发)和LLL(受Lisp启发),都是为面向合约编程而从底层开始设计的语言。专用语言意味着这种语言只在开发以太坊相关应用时才应用;(3)很多基于区块链的DApps和Tools都是用的Go语言;(4)2017年著名的ICO明星项目Teos则使用了极其小众的 Michelson 与 OCaml 作为编程语言,等等。9 [# v7 R9 w# l$ T1 F
       . a, u: d) C; Z+ v2 W
% }5 y$ D3 x4 E) z+ x+ F
数量众多的开发语言
4 c1 C& [8 [- q' [世界上编程语言多达上五十多种,但尴尬的是,没有哪一种语言能够占据绝对优势。# j1 R  `* U1 f) u; c  s
国内著名经济学家朱嘉明认为,在现实中,很可能发生因为任何一种编程语言自身不足,以及不同的编程语言不足的迭加,对现有区块链造成本源性的伤害。
1 }( C) G' T; Y/ Z其次,区块链编程语言主要依赖C++、Java、Go等几种 “高阶语言”,而这些所谓的高阶语言目前还存在诸多不完善之处。1 u& s) N4 x4 x1 N( I0 @8 F
以Go为例,创建时间是2009年,距今只有10年,其“错误处理机制”、“垃圾回收器”与“编译器”等逻辑功能,还需要逐步完善,才能满足未来区块链开发需要。
2 M3 _( s' R: n, M5 g; c同时,朱嘉明还认为:现有的计算机语言正在面临与其它新技术的融合,进而影响区块链的技术体系。例如,人工智能技术和计算机语言的融合,很可能引发计算机语言系统的变革。  W5 F8 w1 ~# y! W  V3 b  R
       % I+ U' X! y2 Y' h( b

2 P% t# E! }0 J4 C7 s( \     , e1 r* {2 @' V6 E
软件失效的逻辑2 z, U$ M9 O) H
最后,由邹均等编写的《区块链核心技术与应用》这本书中还提到了编程人员的自觉和非自觉的错误。
8 _- n5 l7 z2 X& ?* ^+ ]编程人员的错误,会导致软件缺陷,而软件缺陷又会导致软件故障。软件故障是指软件在运行过程中导致不希望出现的错误,如果不加以适当处理,就会导致软件失效。
6 \0 H' u  \6 F8 [; u区块链技术一般运行在相对不可信的公开环境,没有专门的维护人员,更不可能做到像一般软件那样24小时公开维护,因此就要求软件要有高度的稳健性,但是现实情况却往往不是这样的。3 v. ]# B" L$ N+ c* O: o) U& U
人为导致的漏洞,也会让区块链资产化为乌有,这种案例也屡见不鲜。
" d: V" K7 b2 T; S7 q% v- P0 b4月22日中午,有黑客利用以太坊 ERC-20智能合约中BatchOverFlow漏洞攻击BEC(美链的代币“美蜜”)智能合约,成功向两个地址转出了天量级别的 BEC代币,导致市场上海量BEC被抛售。此事使得当日BEC的价值几乎归零。$ |$ b2 c# H3 K, O' f- g( R4 E

  ]. Q$ Y8 j2 k: p7 g0 R5 ^( D7 T4 M
     1 n$ M, x. a- K. t- H
4月22日当天,BEC价格从0.32美金跌到0.02美金; D3 K: n5 l" t- k' g: k
4月25日,仅仅三天后,另一个智能合约SmartMesh(SMT)曝出漏洞,交易所表示,因SMT出现异常交易,各交易平台暂停SMT的充提和交易。
8 C* {! e4 [9 @* Q5 L5 ?现实世界里,财物失窃尚能够通过立案侦查追回损失。但是在互联网的世界里,尽管数字货币“钱途”无量,一旦被黑却血本无归。+ w) ]! D0 }% l6 l1 _- ]" {" g
因此,代码进步十分重要,但是程序员素养,对行业进步更为重要。
% O  T7 o; n. H! ]# O1 T' d. j2 y. m0 F
2: i* D- M! a; P* H) D/ f' V
博弈论的局限
; ~7 w* y; X- Z% }8 z中本聪在白皮书中提到,比特币是一种点对点的电子现金系统。实际上比特币背后的共识机制也是点对点进行的,一台台矿机合作变成矿场,矿场之间通过矿池连接起来,在互相博弈中,形成一种平衡状态。
1 w  `) i7 d7 d' j这种博弈状态的平衡,在朱嘉明看来,建立在“博弈论”基础上的“纳什均衡”最接近反映区块链共识系统的状态。) O7 [0 b8 j; c& T% f
       2 C" g( y! D( d
" v, p0 `4 H$ z5 }' ~* _4 W+ g
纳什均衡是博弈论中的一种情况
9 }" p) S- E# k7 W6 ]“纳什均衡”是指,在一个博弈过程中,博弈双方都没有改变自己策略的动力,因为任何单方面改变自己的策略,都会导致自己的收益减少。举个例子,以即将来临的双十一为例,淘宝上两家旗舰店都在打价格战,任何一方在活动期间都不敢随便涨价,因为任何涨价行为都会导致自己一方失去优势。
- ~% Q2 ~; [  j0 M无论是比特币点对点的支付系统,还是矿工之间的挖矿竞争,都无法摆脱一个问题,在转帐、挖矿过程中每个节点都存在竞争,竞争的结果就是谁付出的矿工费用越高,谁的交易越快完成。3 V7 b8 R% f, |9 E) M) B
但是实际上,朱嘉明认为,这种“纳什均衡”状态下的博弈,是当年诺伊曼和纳什研究的是有限“节点”下的小规模博弈,早已经不足以面对“由几十亿节点的庞大对象构成的社会、经济等复杂行为”。
8 \# d, Z* q4 I% x5 v2 v' c: _当然也无法支持目前比特币、区块链系统节点“几何级数”的发展规模。
# U" ~0 V. f& ]7 g# e" P     : a& Q4 a! \3 v1 s8 ?

6 a' D$ V6 c6 m+ M* h; }. B3 v比特币全网算力是47073540.92 TH/s, W$ R) `- O5 s6 l. \5 X8 l
目前,比特币全网算力是47073540.92 TH/s,市面上最常见的矿机是比特大陆的蚂蚁S9矿机,官方给出的这台矿机的额定算力时14.5TH/s,简单算个除法,结果就是全球比特币网络运行着324.6万台蚂蚁S9。+ L3 D9 @' T# H: r* |% A0 `" E6 P/ m- h
      
' W5 \; @' `# s4 ?: X4 V; G4 C8 A
( J7 p" N, E; Q! M) p! ?. w" s+ h9 y蚂蚁S9参数
/ F1 k4 ?( i7 e8 f5 ~3 I+ [但是实际上,目前比特币矿场中还运行着很多算力低于S9的矿机,这就意味着全球比特币矿机数量远大于324.9万台。
5 P; D+ w5 S/ @9 T6 u在数百万的规模上实现矿机、矿场、矿池之间的博弈平衡,绝对不是个简单的算术问题。实际上,比特币全网算力还处于不断增长中,这种指数级别的增长,正面临“失控”着状态。目前比特币矿业消耗电力已经超过整个大英帝国的用电量。
, \- s7 ]* x. W6 Z& X* p研究机构曾做出过这样的统计:如果按照去年11月份“比特币挖矿耗电量”增长速度来计算,到2019年7月,比特币挖矿耗电量将超过如今美国全国的用电量。
1 @% I6 U4 Z" d. s. z* O' @      
, p) ]& j4 J* R, W1 f/ ?3 G
, w+ s$ Z( b. j8 K, _3 A/ G# F2010年以来,比特币全网算力增长趋势
' s* e; H$ D. M4 E& N5 k同时随着全球比特币用户增长,比特币转账也正在消耗越来越多的“手续费”,网络拥堵就像悬在每个矿工、用户头上的“达摩克利斯之剑”,随时都有可能造成巨大的负面影响。4 `  C: X9 y; ?) z
显然,“纳什均衡”状态下的博弈论已经无法支撑以比特币为代表的区块链技术的前行。亟待进行一场新的基础科学的变革。7 f( b+ ~( k) D) K, r+ F8 s

5 v& w0 `' l- t% ?37 i  i+ O8 M; m" r% S$ ^  A" _  S
哈希算法的掣肘/ @3 x' d3 k2 ^9 u- N% q
“区块链技术的核心其实是密码学,密码学的重点则是哈希函数。”《区块链核心应用与开发》这本书提到。
; q' r7 v; y+ a你在区块链上的每一笔转账、挖矿、应用开发等等,只要涉及链上数据处理,都会涉及哈希函数。而素数与数论则与哈希函数联系紧密。4 B% I/ T1 D% \
我们经常说的比特币POW算法本质是一个哈希函数。1 \/ x  `3 b1 N9 f0 ~- p
事实上,已经有很多哈希函数被设计出来并广泛应用,支付宝、微信、银行的加密无不使用哈希函数。不过Hash函数一般安全寿命都不长,被认为安全的算法往往没能使用多久就被成功攻击,新的更安全的算法相继被设计出来,而每一个被公认为安全可靠的算法都有及其严格的审计过程。% Y5 @) h0 X8 R; I. m% k2 P4 }
      
, g; q3 o+ v4 [( p, ~) y/ W9 J7 G6 I6 u3 x- _0 Y0 L2 I: I
SHA256对“哈希”加密2 d1 f: Q4 V5 _* [7 A& [
加密算法SHA家族的更迭史最能说明这个问题,从1993年SHA0被发明,在不断被破解与重新发明的较量中,目前已经发展到第五代SHA-512。
2 w5 @9 ^3 O3 C' F% f在币圈中我们经常说某某币发明了某种算法,其实主要都是使用那些被认证过的安全算法,或是单独使用,或是排列组合使用。; r- {" R8 h7 a8 o; \' \7 i$ u
而哈希函数与数学问题关系十分紧密,具体是指数论与素数问题。
/ G3 B" {; W0 f# F+ c; ~% p6 P3 }* }; r6 I+ J0 \
       2 `" k7 p! D* Y
《区块链核心应用于开发》这本书认为,目前数论还处于发展状态,哈希函数当然也处于发展状态,这就决定了区块链技术还存在诸多算法不当,进而导致区块链技术性能不足。
5 @2 @# T* ~- j. R3 \; B8 d比特币的不可扩展性、效率低下、升级困难,很大程度上就是该逻辑导致。因为扩展性问题,导致了比特币在2017年被迫分叉。总的来说,区块链技术的效率低下问题,在一定程度上还是数学问题。
; q) `  u0 t& O( C' c0 q有人可能会问,数论是什么?素数又是什么?
7 Z9 F  k$ x. x& `2 @9 L* z通俗理解,一切数学问题都可以归结为数论问题,因此素数问题也属于数论问题。
! w' L% l2 f# p9 G      
0 G" E4 T- V7 t
% i* F, s$ p% o3 _3 H       4 R# E- S. C; T4 q) N
早在公元前300年欧几里得就证明了有无穷多个素数,在随后接近2000年的时间内,主要内容是以寻找素数通项公式为主要思想。这方面主要的代表人物有德国数学家高斯,英国著名数论学家哈代、李特伍德、拉马努金等等。/ Q7 O5 v6 ~9 f8 `( q. \8 z( m
今年9月20日,与证明“黎曼猜想”相关的新闻,在网络上闹得沸沸扬扬。知名数学家迈克尔· 阿蒂亚爵士宣布将会证明黎曼猜想,这引起了区块链行业从业者的关注。为什么?
, V4 ^$ Q& B% H4 ~- g8 I/ i“一旦黎曼猜想被证实,就意味着素数出现规律就能找到,基于此的加密可能也就不安全了。”从事数学研究的阿岚认为。
6 d6 t, {: ?$ W% g* |; J8 }因此,博弈论、代码语言进步、数学理论发展,对区块链技术进步都有着不可小觑的影响。; {1 _0 Y' u0 m. p1 k& p$ `
----------------------3 U4 w# i& z: ~
比特币诞生至今,10年过去了,期间被死亡200多次,被分叉20多次,但是任何一次危机都没能成功“杀死”比特币。" [( ^; Z- \" D' o3 n) E+ J
比特币背后的区块链技术,虽然面临数学问题、博弈论问题、代码漏洞问题,但是这些也没能阻挡区块链行业的从无到有,从落魄到发荣的历史进程。) Q" [1 x& h- q$ E. _9 Z/ o7 o5 @* Z3 p
而成功度过每一次危机,都能让这项技术浴火重生、凤凰涅槃。
* y7 E; ~0 ^6 }- Z虽然目前区块链技术并不成熟、加密货币还没有完全被主流认可,但是时间会对这些问题做最好的注脚。' d8 Q% k! E! ^8 @% Q& t
正如思想家阿卜·法拉兹所言:“暂时的失利,比暂时的胜利好得多。”
BitMere.com 比特池塘系信息发布平台,比特池塘仅提供信息存储空间服务。
声明:该文观点仅代表作者本人,本文不代表比特池塘立场,且不构成建议,请谨慎对待。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

成为第一个吐槽的人

123458446 小学生
  • 粉丝

    0

  • 关注

    0

  • 主题

    7