以太坊基础层接下来面临的一大挑战就是处理日渐增加的状态数据:当前以太坊区块链的状态数据约有100GB,而且每年大约会增加50GB。日益膨胀的状态会让同步以太坊区块链、担当区块链的验证者变得越来越困难,还有使网络陷入中心化的风险;尤其,状态数据的增长还有可能变得更快。
现在,人们提出了两类技术作为短期内的解决方案:
状态保质期:从状态中移除那些近期没有被访问的状态对象,并且,在“复活”这些过期的状态对象时需要提供见证数据。这将使?每个节点?都要存储的状态数据限制在20~50GB。
弱无状态性:仅要求区块生产者存储状态,而所有其他节点都无需存储状态即可验证区块。
当然,也有更长期的选择如“完全无状态性”:可以认为是上述两种方案的极端形式,但更具有挑战性,因此可以认为在短期内没有投入太多时间的必要。
金色热搜榜:GAS居于榜首:根据金色财经排行榜数据显示,过去24小时内,GAS搜索量高居榜首。具体前五名单如下:GAS、ANT、DAC、IOTA、XMR。[2020/12/15 15:17:11]
当然,状态保质期方案和弱无状态性也面临许多挑战),不过,不论哪一种方案,近来都有可观的进步,可以大大缓解我们面临的困难。
关于状态保质期方案,关键难点在于:
如何组织状态的结构,使得不用的部分就会过期?我们是在账户层实现它,还是在存储槽层面实现它)
灭活状态对象时应采取什么样的流程?尤其是,我们是接连不断地灭活状态对象,还是每隔一段时间实施一次灭活行动?“ReGenesis”就是后面这种策略的代称。
如何处理“复活冲突”问题?复活冲突是一个重要的概念。假设某些账户或存储槽在某些地址/位置创建好之后过期了;然后,该账户/存储槽又在相同的位置被重新写入;最后,有些人又尝试复活最初那个已经过期的对象。我们该如何解决这个过期又复活的状态与那个新创建的状态之间的冲突?我的文章有专门的一节详细描述了这个问题。
金色晨讯 | 7月22日隔夜重要动态一览:21:00-7:00关键词:以太坊测试网、Defi、国家数字货币
1.以太坊2.0公开测试网将于8月4日发布。
2.标普500指数及道琼斯指数收盘上涨。
3.全球新冠肺炎确诊病例累计超1500万例。
4.Robinhood前加密货币负责人已离职。
5.CME比特币期货7月合约收涨2.23%。
6.Defi需求推动以太坊交易费增至2018年年中以来高点。
7.去中心化交易所7月份交易量突破16亿美元 再创历史新高。
8.比特币期货未平仓合约自3月以来首次突破40亿美元。
9.哈萨克斯坦反腐局局长建议使用国家数字货币打击腐败。[2020/7/22]
至于弱无状态性,关键难点在于:
如何使用Gas重定价来限制见证数据的上限?,就仍然需要为访问每一个合约代码块施加成本)
分析 | 金色盘面:NEO/USDT再次反弹:金色盘面综合分析:NEO/USDT继续反弹,1小时内涨幅4%,上方继续关注阻力14.60,突破才能真正打开上行空间。[2018/8/16]
见证数据的大小:见证数据即向无状态的客户端提供的、用于验证区块有效性的额外数据;这部分数据,即使有了合适的重定价措施,也有约4MB,对于我们这个每13秒就要广播一次区块的网络来说,还是太大了。
事务的广播:如果客户端并不能直接访问状态来验证事务本身的有效性,那事务要怎么在网络间传播、验证呢?
幸运的是,近来两种方法都取得了许多进展,这些进展似乎能解决绝大多数困扰:
一些技术能让ReGenesis类型的的状态保质期方案最小化复活冲突
金色财经现场报道 开拍网创始人兼CEO梁羽:区块链世界应该是分布式的:金色财经现场报道,在2018FINWISE东京纷智峰会上,星链 StarChain 投资人、开拍网创始人兼CEO梁羽进行以《区块链革命 让Token走进生活》为题的演讲,他指出:区块链技术具有去中介化的特征,不论是平台还是中介公司,都是对于价值剥夺的过程,而不是价值递进的过程。版权的保护和分配问题可以通过区块链技术解决。行业痛点决定未来需求,目前行业存在权属版权问题、行业生态封闭、中心化运作机制、行业数据造假、变现门槛高且渠道为王等问题。区块链世界应该是分布式的、公平的,我们要让Token走进每个人的生活,不要让大家继续对区块链怀有歧义。[2018/5/21]
PiperMerriam研究了如何在事务广播网络中添加见证消息使之适合无状态客户端;以及分布式的状态存储和按需可得性
Verkletree,可以将最糟糕情况下的见证数据大小从约4MB降低到约800kB的区块可达到约780kB,而我们也不得不处理)。看?幻灯片、文档?和?代码。
从理论到实际
两种解决方案都在开发中,可能现在是时候要改观、把它们当成是可行的路径而非研究领域的概念了。至少有一个需要在以太坊上实现。
那这就产生了一个优先级问题:如果我们不得不在两者中挑一个,哪一个更重要一些?Dankrad分析了弱无状态性;如果有详细讲解状态保质期的工作,那对照起来必定会很有趣。
另一个挑战是,让整个生态准备好付出转变的代价。举些例子:
弱无状态性需要用verkletree来替代二进制树,这会使现今所有的默克尔分支验证器失效
Verkletree也要求改变客户端的同步协议
我们还需要添加按代码块计算的Gas成本,这会让某些应用的Gas开销比当前的更大
状态保质期方案需要应用重新设计自己的合约,以高效地使用新状态需要新的版本和架构来处理这一点,虽然不更新也能继续用,但这样会更不便利,Gas开销也会更高)
依赖历史数据访问权的dApp需要切换到一些另外的协议/L2机制中,以访问1年以前的数据
好处
解决上述问题需要极大的毅力。但回报是丰厚的:
让更多人能够运行以太坊节点,帮助以太坊去中心化以及降低“Infura依赖风险”
启用以太坊的无状态验证,大幅降低成为PoS验证者的开销:实现之后,节点甚至可以选择性地验证以太坊应用的数据,例如:仅验证自己参与了见证的区块。这将使我们更接近我们梦寐以求的目标:保证用户使用容易买到的消费级硬件就能成为PoS验证者并且长期不变
提高区块Gas上限:缩减客户端的状态数据规模使我们能安全地大幅提高区块Gas上线,为用户提供更低的交易手续费。更小的状态数据意味着这些数据甚至可以放到内存中,因此每次访问状态的实际开销都会更小,因此我们有望安全地提高区块Gas上限。
让应用开发者更为确信,此番转变之后,协议的经济模型可以更坚固,而且未来不会再有太大改变,因为协议中主要的经济激励不兼容问题已经终结。
希望对该主题我们有更多的讨论,尽快开始开发必要的准备工作,为解决我们的状态问题、为更高的L1效率和可扩展性铺平道路!
原文链接:
https://ethereum-magicians.org/t/weak-statelessness-and-or-state-expiry-coming-soon/5453
作者:??Vitalik
翻译:?阿剑
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。