以太坊挖矿(PoW)流程

配合代码食用(Geth v1.9.0 stable)

以太坊目前有ethash和clique两个共识引擎,其中ethash是用于正式网络的PoW(proof-of-work)共识引擎,clique是用于测试网络的PoA(proof-of-authority)共识引擎

代码流程

1.eth/backend.go
  • New方法创建Ethereum对象时,会调用miner.New方法创建矿工对象,作为Ethereum的一个字段
  • Ethereum.StartMining方法会根据给定的cpu线程数开启挖矿Ethereum.miner.Start
2.miner/miner.go
  • Miner,矿工类型,其字段包括worker(执行挖矿工作),eth(所关联的以太坊节点),engine(共识引擎)等
  • New方法会创建Miner对象,并开启协程go miner.update()处理downloader同步相关事件(在同步开始时停止挖矿,在同步结束或失败后重新开始挖矿)和退出事件
  • Miner.Start方法会调用Miner.worker.start开始挖矿
3.miner/worker.go
  • worker,负责提交新的工作(new work)给共识引擎(进行hash运算或其他方式得到满足条件的block)并收集打包好的block
  • newWorker方法,创建worker并协程启动四个loop:
    • go worker.newWorkLoop(recommit)
      • startCh收到挖矿开始信号,移除pendingTasks中过时的task,提交新的挖矿任务请求(发送newWorkReq到newWorkCh)
      • chainHeadCh收到ChainHeadEvent,移除pendingTasks中过时的task,提交新的挖矿任务请求
      • <-timer.C,default流程,判断如果正在挖矿则重新提交挖矿工作(周期性地拉取价格更高的交易)
      • exitCh收到退出信号,return
    • go worker.mainLoop()
      • newWorkCh收到的新的挖矿任务请求(newWorkReq),执行worker.commitNewWork提交新的task(发送task到taskCh)
      • chainSideCh收到ChainSideEvent,在叔区块未知/正在挖矿/当前叔区块数小于2时,添加该叔区块并执行worker.commit提交新的task
      • txsCh收到NewTxsEvent时,判断如果不在挖矿,执行worker.commitTransactions处理交易并更新快照,否则不做操作
      • exitCh收到退出信号或txsSub/chainHeadSub/chainSideSub收到Error,return
    • go worker.taskLoop()
      • taskCh收到commit方法中提交的task(receipts,state,block,createdAt),将task加入pendingTasks中,并调用worker.engine.Seal方法进行hash运算直到找到一个nonce使得区块的难度值满足要求(即挖矿成功)
      • exitCh收到退出信号,return
    • go worker.resultLoop()
      • resultCh收到共识引擎找到nonce后发送的block:
        • 删除pendingTasks中的记录
        • worker.chain.WriteBlockWithState(block, receipts, task.state)提交block,receipts和state到数据库
        • 广播block(NewMinedBlockEvent{Block: block})
        • 广播链的插入事件(ChainEvent{Block: block, Hash: block.Hash(), Logs: logs}, ChainHeadEvent{Block: block})
        • 将block插入unconfirmed以进行后续的确认
      • exitCh收到退出信号,return
  • worker.commitNewWork具体逻辑:
    • 判断时间戳,要保证timestamp大于上一个块的时间戳,如果timestamp>now+1要等待避免timestamp太超前
    • 构造Header对象
    • 调用worker.engine.Prepare方法,根据parent计算难度值给header的Difficulty字段赋值
    • 提交叔区块
    • 取出交易池pending中的交易并执行worker.commitTransactions,该方法提交交易给evm执行并更新状态
    • 调用worker.commit方法
  • worker.commit具体逻辑:
    • 调用worker.engine.Finalize方法,该方法给矿工计算并加上矿工奖励,计算header.Root并赋值,返回最终定稿的block
    • 判断如果在挖矿,提交新的task(发送task到taskCh)
4.consensus/ethash/sealer.go
  • Ethash.Seal方法,核心逻辑是调用Ethash.mine方法,一直做hash运算直到符合难度值要求,把挖出的block放入worker.resultCh,在worker.resultLoop中处理

流程总结

worker:

  • newWorkLoop:发送newWorkReq到newWorkCh

  • mainLoop:newWorkCh收到newWorkReq,发送task到taskCh

  • taskLoop:taskCh收到task,worker.engine.Seal进行hash运算

consensus:

  • hash解题成功,发送block到worker.resultCh

worker:

  • resultLoop:resultCh收到block,广播和写入
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,313评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,369评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,916评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,333评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,425评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,481评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,491评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,268评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,719评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,004评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,179评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,832评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,510评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,153评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,402评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,045评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,071评论 2 352