楼主: V电13242772558
964 1

[区块链] Avive World算力挖矿系统平台开发 [推广有奖]

  • 0关注
  • 1粉丝

博士生

36%

还不是VIP/贵宾

-

威望
0
论坛币
10 个
通用积分
102.7701
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
3280 点
帖子
90
精华
0
在线时间
219 小时
注册时间
2021-3-2
最后登录
2024-3-1

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
  比特币挖矿的工作量证明原理就是,不断尝试计算区块的哈希,直到计算出一个特定的哈希值,它比难度值要小。

  比特币使用的SHA-256算法可以看作对随机输入产生随机输出,例如,我们对字符串Hello再加上一个数字计算两次SHA-256,根据数字的不同,得到的哈希是完全无规律的256位随机数:

  hash256("Hello?")=????????????????????????????????????????????????????????????????

  大约计算16次,我们可以在得到的哈希中找到首位是0的哈希值,因为首位是0出现的概率是1/16:

  hash256("Hello1")=ffb7a43d629d363026b3309586233ab7ffc1054c4f56f43a92f0054870e7ddc9

  hash256("Hello2")=e085bf19353eb3bd1021661a17cee97181b0b369d8e16c10ffb7b01287a77173

  hash256("Hello3")=c5061965d37b8ed989529bf42eaf8a90c28fa00c3853c7eec586aa8b3922d404

  hash256("Hello4")=42c3104987afc18677179a4a1a984dbfc77e183b414bc6efb00c43b41b213537

  hash256("Hello5")=652dcd7b75d499bcdc61d0c4eda96012e3830557de01426da5b01e214b95cd7a

  hash256("Hello6")=4cc0fbe28abb820085f390d66880ece06297d74d13a6ddbbab3b664582a7a582

  hash256("Hello7")=c3eef05b531b56e79ca38e5f46e6c04f21b0078212a1d8c3500aa38366d9786d

  hash256("Hello8")=cf17d3f38036206cfce464cdcb44d9ccea3f005b7059cff1322c0dd8bf398830

  hash256("Hello9")=1f22981824c821d4e83246e71f207d0e49ad57755889874d43def42af693a077

  hash256("Hello10")=8a1e475d67cfbcea4bcf72d1eee65f15680515f65294c68b203725a9113fa6bf

  hash256("Hello11")=769987b3833f082e31476db0f645f60635fa774d2b92bf0bab00e0a539a2dede

  hash256("Hello12")=c2acd1bb160b1d1e66d769a403e596b174ffab9a39aa7c44d1e670feaa67ab2d

  hash256("Hello13")=dab8b9746f1c0bcf5750e0d878fc17940db446638a477070cf8dca8c3643618a

  hash256("Hello14")=51a575773fccbb5278929c08e788c1ce87e5f44ab356b8760776fd816357f6ff

  hash256("Hello15")=0442e1c38b810f5d3c022fc2820b1d7999149460b83dc680abdebc9c7bd65cae

  如果我们要找出前两位是0的哈希值,理论上需要计算256次,因为00出现的概率是162=256,实际计算44次:

  hash256("Hello44")=00e477f95283a544ffac7a8efc7decb887f5c073e0f3b43b3797b5dafabb49b5

  如果我们要找出前3位是0的哈希值,理论上需要计算163=4096次,实际计算6591次:

  hash256("Hello6591")=0008a883dacb7094d6da1a6cefc6e7cbc13635d024ac15152c4eadba7af8d11c

  如果我们要找出前4位是0的哈希值,理论上需要计算164=6万5千多次,实际计算6万7千多次:

  hash256("Hello67859")=00002e4af0b80d706ae749d22247d91d9b1c2e91547d888e5e7a91bcc0982b87

  如果我们要找出前5位是0的哈希值,理论上需要计算165=104万次,实际计算158万次:

  hash256("Hello1580969")=00000ca640d95329f965bde016b866e75a3e29e1971cf55ffd1344cdb457930e

  如果我们要找出前6位是0的哈希值,理论上需要计算166=1677万次,实际计算1558万次:

  hash256("Hello15583041")=0000009becc5cf8c9e6ba81b1968575a1d15a93112d3bd67f4546f6172ef7e76

  对于给定难度的SHA-256:假设我们用难度1表示必须算出首位1个0,难度2表示必须算出首位两个0,难度N表示必须算出首位N个0,那么,每增加一个难度,计算量将增加16倍。

  对于比特币挖矿来说,就是先给定一个难度值,然后不断变换nonce,计算Block Hash,直到找到一个比给定难度值低的Block Hash,就算成功挖矿。

  我们用简化的方法来说明难度,例如,必须计算出连续17个0开头的哈希值,矿工先确定Prev Hash,Merkle Hash,Timestamp,bits,然后,不断变化nonce来计算哈希,直到找出连续17个0开头的哈希值。我们可以大致推算一下,17个十六进制的0相当于计算了1617次,大约需要计算2.9万亿亿次。

  17个0=1617=295147905179352825856=2.9万亿亿次

  实际的难度是根据bits由一个公式计算出来,比特币协议要求计算出的区块的哈希值比难度值要小,这个区块才算有效:

  Difficulty=402937298

  =0x18 0455d2

  =0x0455d2*28*(0x18-3)

  =106299667504289830835845558415962632664710558339861315584

  =0x00000000000000000455d2000000000000000000000000000000000000000000

  注意,难度值的数值越小,说明哈希值前面的0越多,计算的难度越大。

  比特币网络的难度是不断变化的,它的难度保证大约每10分钟产生一个区块,而难度值在每2015个区块调整一次:如果区块平均生成时间小于10分钟,说明全网算力增加,难度也会增加,如果区块平均生成时间大于10分钟,说明全网算力减少,难度也会减少。因此,难度随着全网算力的增减会动态调整。

  比特币设计时本来打算每2016个区块调整一次难度,也就是两周一次,但是由于第一版代码的一个bug,实际调整周期是2015个区块。

  根据比特币每个区块的难度值和产出时间,就可以推算出整个比特币网络的全网算力。

  比特币网络的全网算力一直在迅速增加。目前,全网算力已经超过了100EH/每秒,也就是大约每秒钟计算1万亿亿次哈希:

  全网算力

  所以比特币的工作量证明被通俗地称之为挖矿。在同一时间,所有矿工都在努力计算下一个区块的哈希。而挖矿难度取决于全网总算力的百分比。举个例子,假设小明拥有全网总算力的百分之一,那么他挖到下一个区块的可能性就是1%,或者说,每挖出100个区块,大约有1个就是小明挖的。

  由于目前全网算力超过了100EH/s,而单机CPU算力不过几M,GPU算力也不过1G,所以,单机挖矿的成功率几乎等于0。比特币挖矿已经从早期的CPU、GPU发展到专用的ASIC芯片构建的矿池挖矿。

  全网算力百分比

  当某个矿工成功找到特定哈希的新区块后,他会立刻向全网广播该区块。其他矿工在收到新区块后,会对新区块进行验证,如果有效,就把它添加到区块链的尾部。同时说明,在本轮工作量证明的竞争中,这个矿工胜出,而其他矿工都失败了。失败的矿工会抛弃自己当前正在计算还没有算完的区块,转而开始计算下一个区块,进行下一轮工作量证明的竞争。

  为什么区块可以安全广播?因为Merkle Hash锁定了该区块的所有交易,而该区块的第一个coinbase交易输出地址是该矿工地址。每个矿工在挖矿时产生的区块数据都是不同的,所以无法窃取别人的工作量。

  比特币总量被限制为约2100万个比特币,初始挖矿奖励为每个区块50个比特币,以后每4年减半。

  共识算法

  如果两个矿工在同一时间各自找到了有效区块,注意,这两个区块是不同的,因为coinbase交易不同,所以Merkle Hash不同,区块哈希也不同。但它们只要符合难度值,就都是有效的。这个时候,网络上的其他矿工应该接收哪个区块并添加到区块链的末尾呢?答案是,都有可能。

  通常,矿工接收先收到的有效区块,由于P2P网络广播的顺序是不确定的,不同的矿工先收到的区块是有可能的不同的。这个时候,我们说区块发生了分叉:

  分叉

  在分叉的情况下,有的矿工在绿色的分叉上继续挖矿,有的矿工在蓝色的分叉上继续挖矿:

  最长链共识

  但是最终,总有一个分叉首先挖到后续区块,这个时候,由于比特币网络采用最长分叉的共识算法,绿色分叉胜出,蓝色分叉被废弃,整个网络上的所有矿工又会继续在最长的链上继续挖矿。

  由于区块链虽然最终会保持数据一致,但是,一个交易可能被打包到一个后续被孤立的区块中。所以,要确认一个交易被永久记录到区块链中,需要对交易进行确认。如果后续的区块被追加到区块链上,实际上就会对原有的交易进行确认,因为链越长,修改的难度越大。一般来说,经过6个区块确认的交易几乎是不可能被修改的。

二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:World Aviv AVI difficulty Difficult

已有 1 人评分经验 收起 理由
kychan + 10 精彩帖子

总评分: 经验 + 10   查看全部评分

沙发
eeabcde 发表于 2024-4-16 08:15:16 |只看作者 |坛友微信交流群
支持分享

使用道具

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注jr
拉您进交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-5-1 12:17