月亮链 月亮链
Ctrl+D收藏月亮链

STA:以太坊阶段式同步:重构完全同步模式(Full Sync)_EdgeSwap

作者:

时间:1900/1/1 0:00:00

阶段式同步重构自Go-Ethereum的完全同步模式,以实现更好的性能。

阶段式同步需要进行大量读写操作。虽然我们的目标是能够在机械硬盘上同步节点,但是我们仍建议使用固态硬盘。

顾名思义,阶段式同步需要依次执行10个阶段。

阶段式同步是如何运作的

Turbo-Geth客户端会向每个对等节点了解该节点的HEAD区块,然后依次执行每个阶段、寻找本地HEAD区块和对等节点的HEAD区块之间缺失的区块。

第一个阶段会设置本地HEAD区块。

各阶段会按顺序执行。在每个阶段执行期间,只有节点本地的状态达到目标状态,该阶段才会结束。

也就是说,在理想情况下,每个阶段只需执行一次,即可完成初始同步。

最后一阶段结束后,整个同步流程会重新开始,寻找新的区块头下载。

以太坊核心开发者:上海升级最后一个主网影子分叉计划于下周进行:金色财经报道,以太坊核心开发者 Tim Beiko 发推总结最新一次的执行层会议讨论内容,以太坊上海升级测试进入最后阶段,最后一个主网影子分叉计划于下周进行,并对最新版本进行跨客户端 EVM 模糊测试。Lodestar 已经发布了一个新的(可选)版本,Prysm 也可能会在升级之前发布。

此前报道,以太坊基金会发布主网 Shapella 公告,将于 UTC 时间 4 月 12 日 22:27:35(北京时间 4 月 13 日 06:27:35)在 epoch 194048 处激活以太坊 Shapella 网络升级。[2023/3/31 13:37:09]

如果你在两个阶段之间重启应用,应用会从第一阶段开始重启。

如果你在某个阶段执行期间重启应用,应用会从当前阶段开始重启,以完成该阶段。

以太坊日销毁量环比下降22%:据欧科云链链上大师数据显示,当前以太坊销毁量为35.62万ETH,单个区块销毁均值为1.1108 ETH;昨日以太坊销毁量为6366 ETH,日销毁量环比下降22.52%。[2021/9/24 17:02:48]

每个阶段需要耗时多久?

通过下方的饼状图,我们可以看出每个阶段的耗时占比。虽然这些数据并不精确,但是足以作为参考。

重组/回退

如果区块链发生重组,我们需要“回退”部分同步数据。

回退指的是从最后一个阶段倒退回第一个阶段。但是,需要注意的一点是,我们执行完回退之后才会更新交易池,因此我们知道新的nonce。

回退的阶段顺序如下例所示。

state.unwindOrder=*Stage{

??//Unwindingoftxpool(reinjectingtransactionsintothepoolneedstohappenafterunwindingexecution)

波卡生态项目Plasm Network:已发布Plasm测试网V1.8.0,以太坊兼容性升级:波卡生态项目Plasm Network官方表示,Plasm测试网V1.8.0已发布,包括集成了Substrate3.0的新功能以及以太坊兼容性升级。[2021/3/4 18:14:59]

??stages,stages,stages,stages,stages,stages,stages,stages,stages,stages,

?}

通过?ETL?进行预处理

在将数据插入数据库之前,一些阶段会使用我们的ETL框架根据键值对数据进行排序。

这样就可以极大减少数据库写入放大的情况。

因此,当我们生成索引或者说哈希值化状态时,我们会执行一个多步骤流程。

将处理过的数据写入位于数据目录的几个临时文件中;

独家|以太坊2.0存款合约地址余额为48994ETH 进度9.34%:金色财经消息,据欧科云链OKLink数据显示,截至下午14时,以太坊2.0存款合约地址已收到48994ETH,距离524288枚ETH启动以太坊2.0创世区块的最低要求已完成9.34%。

近24h以太坊链上活跃地址数逾60.2万,环比上升5.73%;链上交易量近161.69万ETH,环比下降50.32%;链上交易笔数逾105.32万笔,环比下降2.86%。

当前建议Gas费用为32.4Gwei,环比上升44.19%。[2020/11/9 12:05:14]

然后使用一个堆栈把临时文件中的数据插入到数据库中,并且使按照能够最小化数据库写入放大现象的顺序插入数据。

这种优化有时会将写入速度提高几个数量级。

各阶段

每个阶段都包含两个函数,分别是向前推进阶段的ExecFunc?和向后回退阶段的?UnwindFunc。

以太坊核心开发者:正在从以太坊代码库中删除Whisper:以太坊核心开发者Péter Szilágyi刚刚发推称,正在从以太坊代码库中删除Whisper,并打算将其移至对应存储库存档。据悉,Whisper是以太坊的一个通用的分布式通信协议,此前主要用于网络信息传送。[2020/7/22]

从理论上来说,部分阶段可以离线工作,但是当前版本并未实现这一功能。

阶段1:下载区块头

在这一阶段,我们会下载本地HEAD区块和对等节点的HEAD区块之间的所有区块头。

这一阶段是CPU密集型的,适合使用多核处理器,因为要验证区块头的工作量证明。

由于区块链重组,大多数回退都是在这一阶段开始的。

这一阶段会推动本地HEAD的指针。

阶段2:区块哈希值

从区块头中抽取出一个从区块哈希值映射成区块号的索引表,以支持更快速的查找功能,并让同步过程对机械硬盘更为友好。

阶段3:下载区块体

在这一阶段,我们会将上一阶段已下载区块头的区块体也下载下来。

这一阶段需要保持良好的联网连接。绝大多数数据都在这一阶段下载。

阶段4:复原发送者

这一阶段会复原出并存储每个已下载区块中的每笔交易的发送者。

这一阶段同样是CPU密集型的,适合使用多核处理器。

这一阶段不需要联网。

阶段5:执行区块

在这一阶段,我们会执行之前下载的所有区块中的每一笔交易。

需要注意的一点是,在执行区块的过程中,我们不会验证根哈希,甚至不会创建默克尔树。

这一阶段是单线程的,无需联网,需占用大量磁盘空间。如果区块执行失败,可以回退该阶段。

阶段6:计算状态根

这一阶段会构建默克尔树,并验证当前状态的根哈希。

这一阶段也会构建中间哈希值,并将它们存储到数据库中。

如果之前没有存储任何中间哈希值,这一阶段会构建出完整的默克尔树及其根哈希。

如果数据库中没有中间哈希值,这一阶段就会利用区块的历史记录来弄清楚哪些哈希值已经过时,哪些哈希值是最新的,然后使用最新的哈希值来构建部分默克尔树,只重构过时的哈希值。

如果根哈希无法匹配,就会向后回退一个区块。

这一阶段不需要联网。

阶段7:生成哈希值化状态

在执行期间,Turbo-Geth使用无格式状态存储。

无格式状态:在标准状态中,账户和存储项的地址是?keccak256(address)?,但是在一般状态中,二者的地址就是?address?。

尽管如此,为了确保一些API能够正常运作并与其它客户端保持兼容,我们也会生成哈希值化状态。

如果哈希值化状态不是空值,我们会查看历史记录变更集,并且只更新已更改的项。

这个阶段不需要联网。

阶段8、9、10?:生成索引

同步期间会生成3个索引。

这3个索引可能会被禁用,因为所有API都不使用它们。

这一阶段不需要联网。

交易查询索引

该索引表由从交易哈希值到区块号的映射构成。

账户历史索引

该索引存储了从账户地址到区块列表的映射。

存储历史索引

该索引存储了从存储项地址到区块列表的映射。

阶段11:交易池

在这一阶段,我们会启动交易池或更新其状态。例如,如果我们已下载的区块中包含了某些交易,就把这些交易从交易池中移除。

在回退时,我们会将被回退的区块中的交易重新添加到交易池中。

这个阶段不需要联网。

原文链接:

https://github.com/ledgerwatch/turbo-geth/tree/master/eth/stagedsync

作者:?AlexSharov

翻译&校对:闵敏?&?阿剑

标签:STATAGGESHEADbitstamp交易平台百科MetaGold RewardsEdgeSwapHEADZ币

芝麻开门交易所热门资讯
以太坊:紫盈说币:8.14比特币/以太坊晚间分析,以太坊引领大盘乘风破浪吗_以太坊价格今日行情美元

紫盈说币:8.14比特币/以太坊晚间分析,以太坊能再次拉升,引领大盘乘风破浪吗在交易中,我们可以看到这样两种情况,一是任性而行,不懂得也不努力控制自己的行为.

1900/1/1 0:00:00
币虎2020年8月18日18:00上线TW,300,000 TW参与即送!

尊敬的用户:币虎创新区将于2020年8月18日18:00上线TW/USDT交易对,具体时间如下:1.开放充币:2020年8月17日18:00;2.开放交易:2020年8月18日18:00;3.开.

1900/1/1 0:00:00
BITG:Bitget永续合约大数据播报 2020/08/16_ITG

截至今日11:00,BitgetBTC/USDT合约过去24小时成交额13.5亿余美金,相关数据如下.

1900/1/1 0:00:00
CEO:CEO全球站关于NDE上线公告_LINDACEO价格

尊敬的用户:CEO全球站即将开放NDE充值、提现业务,并在币币交易创新区开启NDE/USDT交易对.

1900/1/1 0:00:00
比特币:墨菲言币:11200瀑布是否三顾_数字货币

大家好,我是你们的朋友墨菲言币公众号同步,墨菲bqxy710专注数字货币行情分析,争取为广大币友传递最有价值的币市信息,欢迎广大币友的关注与点赞.

1900/1/1 0:00:00
OIN:研报:2020年Q2主流币种供应透明度一览_ETHA

本报告所涵盖的当前加密资产的概况反映了CoinMetrics管理自由浮动供应值的那些加密资产,其中包括:0x、BasicAttentionToken、Bitcoin、Bitcoincash、Bi.

1900/1/1 0:00:00