Hi 游客

更多精彩,请登录!

比特池塘 区块链前沿 正文

深入浅出区块链之PoW共识

了跳间球
137 0 0
PoW工作量证明
0 T9 F4 n# M, V- T/ C
2 E6 h# ~, I* _" h/ R3 M    因为比特币采用了PoW共识机制,所以这个概念才得以被广泛传播。PoW全称ProofofWork,中文名是工作量证明,PoW共识机制其实是一种设计思路,而不是一种具体的实现。7 V/ e8 e3 j1 W! {

4 A, G3 `5 C# b* |    PoW机制其实早在1997年就被提出了,它早期多被应用在抵抗滥用软件服务的场景中,例如抵抗垃圾邮件(所以PoW在邮件服务系统会有所涉及)。8 ]! r2 o9 o, }3 _
1 P9 Z9 J/ T: i+ V
    为了防止垃圾消息泛滥,接收者并不直接接受来自任意发送者的消息,所以在一次有效的会话中,发送者需要计算一个按照规则约定难题的答案,发送给接受者的同时,需要附带验证这个答案,如果这个答案被验证有效,那么接受者才会接受这个消息。
2 B$ b) \( D1 u& g& d/ T" F8 e8 N8 E( e& \
    可以看出PoW的核心设计思路是提出一个计算难题,但是这个难题答案的验证过程是非常容易的,这种特性我们称之为计算不对称特性,我们在“浅谈区块链共识机制”中举的24点游戏的例子就具备了计算不对称特性。- ?! F. q+ _3 W$ y0 S4 w8 L! S6 m3 D
! M; _" d& M8 ]2 ?$ r7 x- j: I5 r9 E" o
    如何理解区块链PoW
' E  U! @# L! q) {& y# e, q% `) }/ @0 F9 D1 m3 x+ h
    上面介绍了一般的PoW是什么,那么区块链上的PoW又是如何设计的呢,我们还是以比特币为例子来讲一讲。
3 U1 r- [6 f! F; F* m/ Z! g* j5 P, q
    在分析拜占庭将军问题的时候可以看出,如果所有节点在同一时刻发起提案,那么这个系统的记账过程将会非常的复杂混乱,为了降低具有提案权的节点数量,采用工作量证明不失为一个好办法。
3 q  \! N& B5 x* N* h5 n2 U( v, R! s
    所以我们需要构造一个计算不对称的难题,这个难题在比特币中被选定为以SHA256算法计算一个目标哈希,使得这个哈希值符合前N位全是0。
( W% R3 |% b5 n0 Z" I( o
- c% v, f% _. O6 j/ X: o1 [) ^    实际挖矿的基本步骤如下。
, K4 W! Y  o( N$ [8 r' {0 ?% Z& R: x. V9 |2 D
    生成Coinbase交易,并与其他所有准备打包进区块的交易组成交易列表,并生成默克尔哈希;4 w6 U: R" y  p

  C( O$ E9 k+ k3 X( [    把默克尔哈希及其他相关字段组装成区块头,将区块头(BlockHeader)作为工作量证明的输入,区块头中包含了前一区块的哈希,区块头一共80字节数据;
% N5 o( o# z2 B4 }# M) f( Y/ d6 Q9 R$ S( W8 i! N# U
    不停地变更区块头中的随机数即nonce的数值,也就是暴力搜索,并对每次变更后的的区块头做双重SHA256运算,即SHA256(SHA256(Block_Header))),将结果值与当前网络的目标值做对比,如果小于目标值,则解题成功,工作量证明完成。0 m2 ?' Y9 s( _( Y: q8 i

$ J. ]# Q6 [5 H  T, J    如果更深程度去理解的话,PoW机制是将现实世界的物理资源转化成区块链上虚拟资源的过程,这种转化为区块链提供了可信的前提。* z4 i" a& f5 X% ?% b
) ^8 _1 ?0 M/ _! t
    PoW挖矿的发展历程
( S& E0 [% h' Q3 H; o
7 W3 ~; {5 H: }; s( g9 `' E    好了,现在我们知道了,PoW的过程其实就是计算一个难题解的过程。' o3 Q) v  t# S- \) Q
- G/ @/ v$ T6 F! F: d
    在区块链的发展史上,PoW经历了大致两个阶段。分为早期分散挖矿阶段和中心化矿池挖矿阶段。我们目前处于第二个阶段,并且将会长期处于这个阶段。, J" F, [1 W5 f8 K$ z! N0 M( d1 V
: X4 _" L; Z7 m5 g" H/ T
    早期分散挖矿是中本聪的愿景,期望是1CPU=1票,所以如果CPU挖矿,那么将会是非常理想化的情况,而现实的情况是,SHA256只需要非常简单的重复计算逻辑,它不需要复杂的逻辑控制。, u: }- q& A- c. N/ b9 N. S) o
; r$ l) w9 @- R, e( |) C
    那么CPU这种重控制逻辑,轻重复计算的计算单元来搞这么低端的暴力计算非常吃力不讨好,大部分人的第一反应肯定是用GPU呀,非常正确。
, r# Z2 \  `5 Q: I9 H( m+ L' [% k8 i9 Z- p
    所以这个时期,出现了GPU挖矿,它的效率是CPU的十几甚至上百倍,那么1CPU=1票的逻辑就被打破了,挖矿工具的改变让人们意识到挖矿技术也是极大改进的。除了GPU挖矿,我们还有AISC芯片挖矿,这部分内容我们在讨论挖矿算法分类时会详细讲解。
+ N% L3 g& ^# h# C- V2 h
) y" p+ i/ S9 a) j. W    同期我们也慢慢进入到了中心化挖矿阶段。中心化挖矿很好理解,算力如果越分散,也就意味着竞争越激烈,如果某个节点计算出答案了,那么也意味着其他矿工这段时间的工作量几乎都白费了,投入了物理资源结果零收益,可以说是负收益。& l( s0 E, R2 Y; A2 \! @- R1 t

$ x$ Y: g( C* _, z# A    那怎么办呢?思路就是把分散的算力汇聚到一个池子里面,这个池子我们称作矿池,就像四面八方的小溪流最终汇总成一条大江一样。8 _' v& \( ~: C" w6 M
7 Y% F  ~  x" q* J' z
    矿工参与到某个矿池,相当于矿工把算力租给矿池了,与其他矿工联合挖矿,最后看起来矿池这个节点的算力就会很大,获得记账权的概率就越大,如果这个矿池计算出了答案,将获得Coinbase的奖励,矿池就会按既定的分配比例打给每一位参与的矿工。
% y* `7 u+ i& ]8 W7 ~1 A
( _% p' O6 A8 A# I- b+ ~, h- a) A    矿池作为一个中心节点,可以被矿工连接,而在比特币全网来看,矿池节点本质上也只是一个全节点,它与其他全节点一起组成了比特币的点对点网络,特殊的地方仅仅在于它可以产生新的区块。9 H7 \2 E* o% M- m) e- _
: S* @; y4 J; a* U
    PoW挖矿算法分类与简介
7 W# m8 U3 U* g/ P3 @" o0 [- }! Q6 W3 L& d' `/ h
    PoW挖矿算法大致分为两个大类,第一类叫做计算困难,第二类叫内存困难。
4 p# h$ E& u8 r( T6 }4 U" h! c
' K8 y9 Q; i, P- ?    这两类的区别在于对于提供工作量证明的组件要求不同。我们知道计算机的组成分为计算单元和存储单元,通过以往的编程经验我们还可以知道,一个计算机的瓶颈往往是IO,如果要制造大量的IO操作,可以通过写程序撑大内存,制造大量的数据处理过程,使工作量证明从计算单元转变为存储单元。
, J! v6 o9 A- G" F* U
( v" G  P3 w: b/ [+ Z9 \5 \, f2 ~    那为什么要这么做呢?
4 ?  R. b- W8 \& I8 N* R+ m4 G/ q* y, j, H8 N8 f
    其实在PoW挖矿中心化以后,又出现了一次挖矿工具改进,这次超越了GPU,人们先是尝试在FPGA上尝试SHA256的计算过程,结果计算效率成倍于GPU。
" z8 P) y* Z' h$ L0 m2 i+ @* Z: _8 n* V* a1 U6 b1 @+ T, l, T7 Y
    FPGA出现的时间比较短暂,最终人们开发出了ASIC专业芯片来计算SHA256,这就是我们常说的专业矿机。& T) K, v5 \$ W4 m4 s
. s6 E! T  T* f% Z$ Q
    专业矿机的出现加速了PoW挖矿的中心化过程,因为购买专业矿机需要额外的时间和精力,配置运行还有一定的门槛,普通人也只能从专业机构手里购买专业矿机。, T, P& j7 L# m9 d) S! j- H; n
6 v' i: o# g2 l! _1 p9 m
    所以这些专业矿机直接就是数字货币印钞机,生产专业挖矿芯片的商业公司几乎成了数字货币的货币发行司,这不得不说到市值直逼英伟达的比特大陆公司,它用的就是专业生产数字货币挖矿芯片。3 }$ [( P( \. n2 B8 ]9 Z% V

% W  g% a7 A6 H3 S$ v    新的数字货币开发者们为了防止情况重演,不断发明新的挖矿算法。有名的有Scrypt、X11、SHA-3,不过这些依然是计算困难型的挖矿算法,依然没有逃脱出现专业矿机的命运。. j5 N  ^) [, d( g1 P; l
6 O# }2 [8 |  w, c6 e' G- _
    这里不得不提到以太坊的PoW挖矿算法:ETHASH,ETHASH是Dagger-Hashimoto的修改版本,它是典型的内存困难型挖矿算法。直到如今,也没有芯片厂商设计出挖矿芯片。, @9 S+ K5 x1 b& w4 N- v
0 Q. c/ t3 U- [- R; Y
    正如我们上文所说,因为工作量证明要求的组件从计算资源转变为内存资源,而对内存的高要求使得矿工必须加内存。4 P% i: }" h0 f$ I

& }' |) G/ {5 b    在专业矿机上加一块内存的收益与在GPU上加一块内存获得的收益是差不多的,所以厂商并没有研发内存困难型专业矿机的动力,没有专业矿机的出现,这从某种程度上也缓解了算力中心化的问题。' R8 A1 P7 M3 B: Q' i9 w

; t& V; Y  q/ A    PoW的优势和劣势- M( a/ @  V- M$ d* z

* t( k! {9 ^8 H, P" h! C    PoW共识的内在优势在于可以稳定币价,因为在PoW币种下,矿工的纯收益来自Coinbase奖励减去设备和运营成本,成本会驱使矿工至少将币价维持在一个稳定水平,所以攻击者很难在短时间内获得大量算力来攻击主链。
% f: f3 t6 s# X4 u2 W5 `6 O+ ~1 ~4 h; v  n5 E) a0 x, d
    PoW共识的外在优势是目前它看起来依然是工业成熟度最高的区块共识算法,所以在用户信任度上、矿工基础上都有很好的受众。( g7 w% i! e7 v! J9 g
9 ]1 O0 R& }+ N$ b) ~, r9 R
    PoW共识最大的缺点是非常消耗计算资源,耗电耗能源,这一点也一直为人们所诟病。因为每次产生新的区块都会让相当一部分工作量证明白白浪费了,也就是将计算资源浪费了。
% M- x! g6 L0 T2 i# c" m; |+ j0 m
& Y9 ]* e" d# d2 O& L* J' y& L; {    目前来看这个是无解的,只要是PoW共识,一定会遇到计算资源浪费的问题。不过人们也想了一些改进方案,早期如素数币,近期有比原币,它们都号称深度学习友好型的工作量证明方法。
- V1 r; H- A: |1 S1 O) N4 Q* X$ L. v2 X* H; D5 z5 {6 a* \
    从理论上来看,PoW会一直有51%算力攻击的问题,即攻击者只需要购买超过全网51%算力设备,即可发起“双花攻击”,甚至“重放攻击”等多种高收益攻击,这个问题目前没有解决方案。  a; T$ J: i* y6 }, T/ e1 [
7 V4 }2 y' {# X2 a+ B
    除了51%攻击,PoW共识还有自私挖矿的问题,自私挖矿是一种特殊的攻击类型,不会影响区块链正常运转,但是会形成矿霸,间接造成51%攻击,我们就曾经遇到过这样的自私挖矿攻击。; `9 W. J0 L. T) w8 U( Y- j

# R" K* C* z7 t    PoW共识机制是一种简单粗暴的共识算法,它不要求高质量的P2P网络资源,它可以为公链提供稳定有效的记账者筛选机制。同时它也面临了挖矿中心化严重的问题,这也促使人们研究出了新的共识机制,我们留到下一篇讲解。
  l3 h) ?, m3 F5 B+ u
' x0 F( D# Q# c* @: `' @; G/ f    总结
" I$ f% P* D- D( A* d. F. b' w! ^/ D9 \3 B$ t+ i' d6 p
    今天我介绍了PoW工作量证明,又介绍了发展历程和算法分类,最后提到了PoW的优势和缺陷。相信你对PoW机制的理解可以更加深入了。( t5 _5 x, u# |% @! c/ q

4 s# J; O8 A) F1 `6 j    以上内容由本人搜集整理,并不代表任何投资建议,仅仅作为学习参考,也不作为买卖依据。市场有风险,投资需谨慎!同时我也为大家总结准备了500份区块链白皮书、区块链行业词典、公链项目大盘、技术波段看线等优质免费大礼包。联系(hyrik2020)免费获取500份中文版区块链白皮书:其中BTC、ETH、EOS、ont、HT、BU、PAI、ADA等(了解数字货币价值的核心因素)。1 t/ ~# O6 u. ?4 N% ^5 z9 W3 C$ O; q
9 F9 k8 y/ Z* x3 }  B5 u9 J; _4 O
    最后还是那句话,2018年是区块链发展元年,未来区块链会是一个新的发展趋势,错过了这个风口,你将会像当年错过互联网时代、错过电商、错过微商时代一样,再一次错过整个区块链时代。
! Z( h/ ]' V3 ?# Z; ^/ D
2 o# A) k  ]2 f  `    写文章总要有结束语,最后用一段话来做结束语:1、关于区块链发展:短期是底层技术,中期是应用场景,长期是改造社会。" c4 E9 W! s4 y
9 K1 Y8 a+ k9 s3 N, j
    2、关于区块链参与各方:币圈看到流量,链圈看到共识,玄学圈看到革命。1 @2 r* R5 e# n) @# }
# }1 f  k" K3 g  R# W; v
    3、关于区块链怎么改造社会:短期是通证和激励,中期是货币和经济,长期是社会。: ^5 `. w, c& @/ p, S: d

- e  O' I/ w, e; Z4 z    4、关于应用落地:前期是比特币和炒币工具,短期是公链,中期是轻应用,长期是去中介化场景。4 P# P9 _5 y+ }2 ~5 C6 H' r
3 t2 n$ o8 o4 u, J3 V3 `# e# L
    5、关于炒币:长期看人口,中期看供求,短期看监管。* Q% W% F% n: i- ^, ?0 a% A8 z

  U) G8 L) R' b5 G' Q: D$ j    6、关于区块链本质:一边是技术,一边是通证,一边是社区,链币社区不分家。
- t( b* {3 ?( e6 t8 b, ~( j+ T
# R( ?! k$ n* \9 g. [6 c* N) ?& V- l    7、关于技术模型:短期看共识机制,中期看操作系统,长期看DAPP生态。! J; J6 ?; S# [. `$ p0 L! B
( I8 R- |$ L1 a9 a, \+ [
    8、关于通证模型:短期看发币上市,中期看总量机制,长期看生态使用,终极看通证经济体的参与各方利益平衡。
; ^% T1 O/ H- Z3 z; i3 ^4 I1 w5 f" m9 E# A1 ~) w$ }) N/ I
    9、关于社区治理:短期是自发自理,中期是社区政治,长期是代码法治。
& b6 N( ]( [1 M& f& U
1 F; `3 Y, A3 j( }! g/ n    10、关于通证社区经济体:以前是公司制,现在有非盈利组织,以后是通证社区,终极是人的自由联合。
BitMere.com 比特池塘系信息发布平台,比特池塘仅提供信息存储空间服务。
声明:该文观点仅代表作者本人,本文不代表比特池塘立场,且不构成建议,请谨慎对待。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

成为第一个吐槽的人

了跳间球 小学生
  • 粉丝

    0

  • 关注

    0

  • 主题

    2