「区块链入门笔记」3.1 共识算法-工作量证明

要想整个 P2P 网络维持一份相同的数据,保证每个参与者的公平性,整个体系的所有参与者必须要有统一的协议(共识算法)。

这些协议规则可以划分为两个大的核心:

  • 工作量证明
  • 最长链机制

共识算法的目的就是保证比特币不停地在最长链条上运转,从而保证整个记账系统的一致性和可靠性。

1. 工作量证明

工作量证明(POW)可简单地理解为一份证明,用来确认你做过一定量的工作。

监测工作的整个过程是极为低效的,而对工作的结果进行认证来证明完成了相应的工作量,是一种非常高效的方式。

比如现实生活中的毕业证、驾驶证等,是通过检验结果的方式(通过相关的考试)取得证明。

1.1 起源

工作量证明系统,是一种应对服务攻击和其他服务滥用的经济对策。它要求发起者进行一定量的运算,消耗计算机一定的时间。

哈希现金是一种工作量证明机制,
Hashcash 在防治垃圾邮件中的应用:在电子邮件的消息头中,增加一个 Hashcash 戳记(Hashcash Stamp)散列值。该散列中包含收件人地址,发送时间,salt,该散列值特别之处在于它至少前20位必须是0才是一个合法的Hashcash 戳记。为了得到合法的散列值,发送者必须经过许多次尝试(改变 salt 值)才能获得。一旦生成戳记,不希望每一个给我发送邮件的垃圾邮件制造者都能重复使用它。所以,Hashcash 戳记要带一个日期。这样可以指定时间更早的戳记是非法的。另外 Hashcash 的接收端要实现一个 Double-spending 数据库,用来记录戳记的历史信息。

1.2 工作量证明的基本原理

工作量证明指客户端需要做一定难度的工作得出一个结果,验证方很容易通过验证结果来检查客户端是不是做了相应的工作。

这种方案的一个核心特征是不对称性:工作对于请求方是适中的,对于验证方则是易于验证的。

它与验证码的不同:验证码的设计出发点是易于被人类解决而不易被计算机解决。

img
img

例子:给定一个基本的字符串“Hello, world! ”。工作量要求是:可以在这个字符串后面添加一个叫作 nonce(随机数)的整数值,对添加 nonce 后的字符串进行 SHA-256 哈希运算,如果得到的哈希结果(以十六进制的形式表示)以 0000 开头的,则验证通过。为了达到这个工作量证明的目标。计算机需要不停地递增 nonce 值,对得到的新字符串进行 SHA-256 哈希运算。按照这个规则,需要经过 4251 次计算,才能找到恰好前 4 位为 0 的哈希散列。为了增加复杂性:验证方可以要求请求方对多个字符串进行 SHA-256 运算。

比特币里的工作量证明机制类似,但是更复杂。

1.3 比特币中的工作量证明

一个节点若生成一个新的区块并写入区块链,须解出比特币网络给出的工作量证明迷题。

这道题的3个关键要素是工作量证明函数区块难度值

  • 工作量证明函数是这道题的计算方法
  • 区块决定了这道题的输入数据
  • 难度值决定了解这道题所需要的计算量。

工作量证明函数是 SHA-256。区块是在工作量证明环节产生的。矿工不停地构造区块数据,检验每次计算出的结果是否满足工作量,从而判断该区块是否符合网络难度。区块头即为比特币的工作量证明的输入数据。

难度值是矿工们挖矿的重要参考指标,它决定了矿工大约需要经过多少次哈希运算才能产生一个合法的区块。

比特币的区块大约每 10 分钟生成一个,为了使新区块的产生都基本保持这个速率,难度值必须根据全网算力的变化进行调整。

每隔 2016 个区块,所有节点都会按统一的公式自动调整难度值。

公式:新难度值 = 旧难度值*(过去2016个区块花费时长 / 20160 分钟)

这个公式是由产生最新 2016 个区块的花费时长与期望时长(期望时长为 20160 分钟,即两周,是按每 10 分钟一个区块的产生速率计算出的总时长)比较得出的,根据实际时长与期望时长的比值,进行相应调整。

工作量证明需要有一个目标值。比特币工作量证明的目标值(Target)的计算公式如下:
目标值= 最大目标值/难度值

最大目标值为一个恒定值:0x00000000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF

比特币工作量证明的达成就是矿工计算出来的区块哈希值小于目标值。

比特币工作量证明的过程简单理解成,通过不停地变换区块头(即尝试不同的nonce 值)并将其作为输入,进行 SHA-256 哈希运算,找出一个有特定格式的哈希值的过程(即要求有一定数量的前导 0 )。而要求的前导0的个数越多,难度越大。

可以把比特币矿工解这道工作量证明迷题的步骤大致归纳如下:

  1. 生成 coinbase 交易,并与其他所有准备打包进区块的交易组成交易列表,通过 Merkle Tree 算法生成 Merkle Root Hash。
  2. 把 Merkle Root Hash 及其他相关字段组装成区块头,将区块头的 80 字节数据作为工作量证明的输入。
  3. 不停地变更区块头中的随机数(即 nonce 的数值),并对每次变更后的区块头做双重 SHA-256 运算(即 SHA256(SHA 256(Block_Header))),将结果值哈希反转并与当前网络的目标值对应的十进制字符串做对比,如果小于目标值,则解题成功,工作量证明完成。

![img](file:///storage/emulated/0/Note/images/1526699332810.png)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,236评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,867评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,715评论 0 340
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,899评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,895评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,733评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,085评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,722评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,025评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,696评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,816评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,447评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,057评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,009评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,254评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,204评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,561评论 2 343

推荐阅读更多精彩内容