ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

挖矿是什么意思?

2021-02-27 14:00:16  阅读:218  来源: 互联网

标签:Hash 账单 什么 生成 意思 矿工 区块 挖矿


生成一个区块,链入区块链的过程,就是挖矿。挖矿的人/机器/程序,就是矿工。
首先,先了解一下为何需要矿工去挖矿。

区块链技术为了使每一笔交易都变得可靠,将每一笔账单都保存在网络的每个节点。公开,透明,这让每个人都知道资金的流向,不需要再单独建立一个监管部门来记录每一笔交易信息。

但是,这个账单不是凭空出现,是需要生成的,也就是需要矿工来挖矿。

首先用户拿通证来交易,这时生成了一个订单,矿工拿到订单信息时需要生成合法的账单信息,等到生成成功,矿工会把交易账单分享到各个节点,这时交易才能算是成功完成。

每一笔合法的账单上的信息包含:账单号、交易时间、交易内容、上一笔账单的Hash、和一个数字。

矿工如何生成合法的账单?

所谓合法的账单,是根据每一笔账单上的信息生成的Hash串所决定的,而决定Hash串的标准是根据矿工挖矿的时间来定的,为了不让矿工那么快地挖矿,所以设定了不同的难度。

举个 ,Hash256生成的十六进制一共64位,为了让矿工不那么快地计算Hash值,所以设定个规则,生成Hash串的前10位必须是0(当然也可以是前15位为0),这个账单才能生效。所以,矿工需要不停地更改数字来穷举根据账单信息生成的Hash串。

所以,挖矿本质是执行Hash函数的过程,而Hash函数是一个单输入单输出函数,输入数据就是这个区块头。

比特币区块头共6个字段:

int32_t nVersion; //版本号,4字节

uint256 hashPrevBlock; //前一个区块的区块头hash值,32字节

uint256 hashMerkleRoot; //包含进本区块的所有交易构造的Merkle树根,32字节

uint32_t nTime; //Unix时间戳,4字节

uint32_t nBits; //记录本区块难度,4字节

uint32_t nNonce; //随机数,4字节

所以许多人说“挖矿”很难,因为 Hash 的计算是不可逆的。举例来说,由字符串算出对应的md5值很容易,但由md5值反推出字符串,是不可能的。

所以我们可以认为Hash的结果是完全随机的,要得出前48bit必须是0x00000000FFFF的哈希结果,就如同连续抛48次硬币,每次都得到我们想要的结果,其概率为(1/2)^48

最开始用 CPU 挖矿,过渡到 GPU 挖矿,演化到当前的 ASIC(专业矿机)挖矿、云挖矿……还有人相信量子计算的突破会让区块链体系土崩瓦解(大误,详情可以参考文章https://zhuanlan.zhihu.com/p/92834381)。人类企图以升级设备和计算的速度来突破Hash的计算壁垒,但是随着矿工的数量越来越多,挖矿的难度也在水涨船高。

所以,这究竟是不是一种区块链的自我进化

标签:Hash,账单,什么,生成,意思,矿工,区块,挖矿
来源: https://blog.csdn.net/weixin_55537546/article/details/114172099

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有