以太币挖矿教程| 以太币的挖矿机制全解析
随着以太坊正式运行的临近,询问以太如何挖矿的朋友也越来越多 。这篇文章综合了我们目前所知道的信息,希望能对大家有一些帮助 。由于挖矿算法的设计和改进仍在进行中,以下信息仅供参考 。
限时活动
- 活动一、从欧易OKX注册:http://www.okx.com,可直接领取300元虚拟货币
- 活动二、全球顶尖加密货币交易所,注册即领最高 ¥3000数字盲盒,永久交易手续费返佣10% 。
文章图片
设计目标
抵抗矿机(ASIC Resistance) 。使用专门优化的芯片产生的挖矿优势应该尽可能的小,小到即使使用普通CPU挖矿也能产生收益 。
轻客户端可验证 。轻客户端应该有能力验证每一个块的真实性 。目标是在普通桌面电脑上运行用C实现的验证算法,验证时间小于0.01秒,用Python或者Javascript小于0.1秒,使用内存不超过1MB 。
挖矿算法
以太币(ether)的挖矿算法叫做Ethash, 又名Dashimoto (Dagger-Hashimoto),是Hashimoto算法结合Dagger之后产成的一个变种 。它的特点是挖矿的效率基本与CPU无关,却和内存大小和内存带宽正相关 。对内存大小和带宽的要求意味着那些通过共享内存的方式大规模部署的矿机芯片并不能在挖矿效率上有线性或者超线性(super-linear)的增长 。
接下来让我们看看Dashimoto的基本流程:
对于每一个块(block),先计算出一个种子(seed) 。种子的计算只依赖于当前块的信息,例如block number以及block headers 。
使用种子产生32MB的伪随机数据集,称为cache 。轻客户端需要保存cache 。
基于cache再生成一个1GB大小的数据集,称为the DAG 。这个数据集中的每一个元素都只依赖cache中的某几个元素,换句话说,只要有cache就可以快速计算出DAG中指定位置的元素 。完整的可挖矿的客户端需要保存DAG 。
挖矿可以概括为从DAG中随机选择元素然后对其进行hash的过程 。验证的过程也是一样,只不过不是从DAG里面选择元素,而是基于cache计算得到指定位置的元素,然后验证这个元素集合的hash结果小于某个值 。由于cache很小, 而且指定位置的DAG元素很容易计算,因此验证过程只需要普通CPU和普通内存即可完成 。
cache和DAG每一个周期更新一次,一个周期的长度是1000个块 。也就是说这1000个块产生的cache和DAG是完全一样的,因此挖矿的主要工作在于从DAG中读取数据,而不是更新cache和DAG 。DAG的大小随时间的推移线性增长,从1GB开始,每年增加大约7GB – 因此到2015年12月大约是8GB, 到2016年12月大约15GB 。
注:以上步骤中的数字已经随着开发的推进有了调整,准确值请参考源代码 。
挖矿软件
我们预计在上线之时将有至少两种挖矿方式:
使用Mist客户端(官方客户端实现,基于Go语言)进行CPU挖矿 。
通过以太坊守护进程(eth daemon)和sgminer的组合进行GPU挖矿 。守护进程和sgminer之前的数据通讯可以通过JSON-RPC API完成 。目前有两个API和挖矿有关:eth_getWork以及eth_submitWork 。
【以太币挖矿教程| 以太币的挖矿机制全解析】
- 猫币| 猫币CAT(Catcoin)是用什么挖矿的?
- ETC币| 以太经典etc钱包怎么用?
- 比特币挖矿| 比特币挖矿红利到头了吗?看看这十几家优质矿业怎么说
- 如何获得比特币| 关于如何挖矿赚比特币,你可能并不知道的4件事!
- 以太币挖矿教程| MBAex交易平台iOS下载教程
- 【游戏世界】LOL新老原画对比 新版原画空间感 构图 光影细节明显提升
- 比特币挖矿教程| 比特币合约交易教程具体步骤是什么?
- 比特币挖矿教程| 比特币如何买入和卖出?比特币买入卖出教程
- 如何获得比特币| 比特币矿工费如何计算?比特币矿工费计算公式
- 比特币现金| 比特币挖矿难度预计14天7小时后下调至13.85T