比特币交易平台——以太坊挖矿是根据什么原来来挖矿的

首页 > 挖矿 > 以太坊挖矿 | 以太坊挖矿是根据什么原来来挖矿的

以太坊挖矿是根据什么原来来挖矿的

编辑:蓑衣网 日期:2021-10-28 17:12:38 浏览量:

【以太坊挖矿是根据什么原来来挖矿的】以太坊的共识机制是 PoW(Proof of Work 工作量证明机制),使用的算法是Ethash,这种算法是对 Dagger-Hashimoto算法的改良版本,【以太坊挖矿是根据什么原来来挖矿的】流程大概如下

1.对于每一个块,首先计算一个种子(seed),该种子只和当前块的信息有关;然后根据种子生成一个32M的随机数据集(cache)

2. 根据Cache生成一个1GB大小的数据集合DAG(有向非循环图),它是一个完整的搜索空间,挖矿的过程就是从DAG中随机选择元素(类似于比特币挖矿中查找合适Nonce)再进行哈希运算,可以从Cache快速计算DAG指定位置的元素,进而哈希验证

要求对Cache和DAG进行周期性更新,每1000个块更新一次,并且规定DAG的大小随着时间推移线性增长,从1G开始,每年大约增长7G左右。

【以太坊挖矿是根据什么原来来挖矿的】为了更好的了解这部分。我们可以简单的看下 go-ethereum 的代码

1. 在 miner.go里调用 New方法生成一个矿工。

1234567891011121314151617/**利用区块链创建时候的一些配置,以及共识引擎consensus.Engine等参数先是生成一个矿工,然后让矿工注册一个cpu运算引擎,同时通过 update 来监听同步状态并更新挖矿状态**/funcNew(eth Backend, config *params.ChainConfig, mux *event.TypeMux, engine consensus.Engine) *Miner {miner := &Miner{eth: eth,mux: mux,engine: engine,worker: newWorker(config, engine, common.Address{}, eth, mux),canStart: 1,}miner.Register(NewCpuAgent(eth.Blockchain(), engine))gominer.update()returnminer}

在update方法里有一个需要注意:

有关以太坊挖矿是根据什么原来来挖矿的相关内容分享到这,希望以上蓑衣网小编分享的相关内容能对大家有所帮助。

交易平台快速通道
Copyright © 2021-2022 版权归蓑衣网所有.备案信息: 蜀ICP备19005694号-1
本网页内容、图片、视频为模板演示数据,如有涉及侵犯版权,请联系我们提供书面反馈,我们核实后会立即删除。