13
2022
01

挖矿基本原理

首先,先科普一下为何需要矿工去挖矿。区块链使每一笔交易变得可靠,即将每一笔账单都保存在网络的每个节点。这也就让每个人都知道资金流向,让买卖更加透明,不需要一个监管部门来记录每一笔交易信息。


但是,这个账单是需要生成的,也就是需要矿工来挖矿。首先用户拿币来交易,这时生成了一个订单,矿工拿到订单信息时需要生成合法账单信息,等到生成成功,矿工会把交易账单分享到各个节点,这时交易才能完成。每一笔账单上的信息包含:账单号、交易时间、交易内容、上一笔账单的Hash、和一个数字。其中账单号也就是区块链的块号、交易时间、交易内容、上一笔账单生成的Hash都是无法更改的,所以矿工能够更改的就是最后一项数字了(这里的信息并不完整,需要详细了解请百度或谷歌)。


忘了介绍,矿工如何生成合法的账单?所谓合法的账单,是根据每一笔账单上的信息生成的Hash串所决定的,而决定Hash串的标准是根据矿工挖矿的时间来定的,为了不让矿工那么快地挖矿,所以设定了不同的难度,举个例子,Hash256生成的十六进制一共64位,为了让矿工不那么快地计算Hash值,所以设定个规则,生成Hash串的前10位必须是0(当然也可以是前15位为0),这个账单才能生效。所以,矿工需要不停地更改数字来穷举根据账单信息生成的Hash串。


下面上代码:


#Hash库

import hashlib as hs 

#时间库

import datetime as date

#区块

class Block():

    #构造方法,传入数据包括索引、时间戳、数据、上一笔账单的Hash串、可更改的数字

    def __init__(self,index,timestamp,data,preHash,number):

        self.index = index

        self.timestamp = timestamp

        self.data = data

        self.number = number

        self.preHash = preHash

        self.hash = self.blockHash()

    #生成Hash串

    def blockHash(self):

        sha = hs.sha256()

        sha.update(str(str(self.index) + str(self.timestamp) + str(self.data) + str(self.preHash) + str(self.number)).encode("utf-8"))

        return sha.hexdigest()

#创建初始区块    

def initBlock():

    rst = Block(0,date.datetime.now(),"first","0",0)

    return rst

#创建区块链

blockChain = [initBlock()]

preBlock = blockChain[0]

#测试运行所用时间

starttime = date.datetime.now()

#生成10个区块

for i in range(0,10):

    通过修改数字来生成Hash串

    for j in range(0,10000000000):

        #由于我懒,时间戳、数据都使用了上一个区块的数据,实际需要交易时的数据

        nextBlock = Block(preBlock.index+1,preBlock.timestamp,preBlock.data,preBlock.hash,j)

        #这里只测试了前六个字符为0时的数据,成功则加入区块链

        if nextBlock.hash[:6] == "000000":

            blockChain.append(nextBlock)

            preBlock = nextBlock

            break

    print(preBlock.hash)

#测试运行所用时间

endtime = date.datetime.now()

print((endtime-starttime).seconds)

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

运行结果图:




由图可以看到,只前六位为0生成10个Hash串就耗费833秒,平均一个83.3秒,再往上加所耗费的时间几何倍地增长。

所以要挖矿的小伙伴最好用C/C++编写,并且设备、网络采集信息等都要领先他人才能挖矿。

————————————————

版权声明:本文为CSDN博主「fyq201749」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/fyq201749/article/details/80973103


« 上一篇 下一篇 »

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

登录
用户名
密码
注册
用户名
密码(至少8位)
确认密码
昵称
获取邀请码
邀请码