0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

以太坊无状态客户端是什么

电子设计 来源:电子设计 作者:电子设计 2020-12-25 18:57 次阅读

现在有一个协议转换现象,从理论上来说,它可以转换成很多其他不同的协议,从数学上来看,它就像如下情况。假设我们使用状态转移,STF(S, B) -> S’,其中S和S’是状态,B是区块(或者说它是转账T),并且STF是状态转移函数。那么,我们可以转换为:

S -> S的根状态(也就是说,Merkle树所包含S的32位)。B -> (B, W),其中W是一个“见证者”,Merkle树的分支会提供所有数据的价值,可以执行让B进入STF-> STF’,这可以作为状态根部的输入,以及区块链上的见证者,使用见证者作为“数据库”,任何时候区块的执行都需要阅读任何账户,存储秘钥或者其他状态数据【如果见证者没有包含一些需要被请求的数据】,并且输出新的状态根部。

这就是,全节点只会存储状态根部,并且它会成为矿工的责任来打包这些Merkle树的分支(见证者),以及区块,还有全节点会下载以及验证这些扩展的区块。对于无状态的全节点和常规的全节点来说,在网络中共存,这都是有可能的;你需要获得拥有区块B的翻译区块,附上所需要的见证者,并且在无状态节点存在的不同网络协议上广播(B, W);如果有矿工在这个无状态网络上挖出区块,那么见证者可以很简单地去除,同时区块会在正常的网络上进行重新广播。

假设真实协议中的见证者,最简单的方法就是把它作为RLP编码的对象,这会被客户端解析为{sha3(x): x}关键价值图谱;这个图谱然后可以很简单地嵌入到现在的以太坊中,作为“数据库”布局。

将以上这个想法布局到以太坊上的局限在于,还是需要矿工成为存储状态的全节点。有人会假设这样一个系统,其中转账发出方需要存储全状态Trie(甚至只有和他们相关的部分),而且矿工也是无状态的,但是问题在于以太坊的状态存储入口是动态的。例如,你可以假设getcodesize(sha3(sha3(…sha3(x)…)) % 2**160)的合约形式,其中会有几千个sha3’s。这就导致进入的账户代码只有在几百万gas燃料的计算消耗完成后,才可能知道。因此,转账发出者可以创造一个转账,其中包含新账户的见证者,进行很多计算,然后最后尝试进入一个没有见证者的账户。这就和DAO软分叉漏洞一样。

其中一个的解决方案,就是让转账包含这些账户的静态列表;例如EIP 648,但是需要精确数字,而不是一个范围。但是就会产生一个问题:到时候,转账会通过网络,账户状态,进行扩散,从而因此正确的Merkle树分支可以作为见证者,也许会和转账生成时的正确数据不同。为了解决这个问题,我们把见证者放在转账中的签名数据之外,并且让包含转账信息的矿工在有需要地时候,在转账前对见证者进行调整。如果矿工拥有对所有创建出来的新状态树节点,也就是说,在过去24小时,他们已经获得必要的信息来更新过去24小时公开转账的Merkle树分支。
这项设计有如下优势:

1.矿工和全节点再也不需要存储任何状态。这会让“快速同步”变地非常快(可能只需要几秒)。

2 关于状态存储经济学的问题都会导致例如租赁的设计,并且甚至目前复杂的SSTORE支出/回款架构就会消失,而且区块链经济学能够只专注于价格带宽和计算,这会是更加容易的问题。

3. Disk IO对于全节点和矿工来说,就不会是个问题。Disk IO是以太坊上主要的DoS攻击来源,而且甚至现在它好像是最容易发生的DoS因素。

4. 对指定帐户列表的转账要求附带地增加了高度的可并行性;这在很多方面是EIP 648的高配版本。

5. 对于状态存储的客户端,账户列表让客户端能够从disk预取存储数据,也许是并行的,大概率降低了DoS攻击的漏洞。

6. 在分片区块链中,通过在分片中对客户端进行调整,从而增加安全性;客户端分片调整地越快,在拜占庭容错模型中,这个架构就更加安全。但是,在状态存储的客户端模型中,被洗牌的客户端就会下载新分片中的全部状态。在无状态的客户端中,这部分成本为零,这就让客户端可以在它们创建的每个区块间进行调整。

但是这带来一个问题:谁存储了这个状态?以太坊的关键优势就是这个平台很容易使用,并且用户不需要关心存储私有状态这类细节。因此,为了这类框架能够很好地完成,我们需要复制类似的用户经验。这是一个关于如何做到这一点的混合建议:

1.任何创造出来的新的状态树对象都会默认被全节点保存3个月。这大约有2.5GB的存储空间,而且这就好像“福利储存”,这是基于自愿地基础上由网络提供。我们知道这个层次的服务当然能够基于自愿的基础来提供,因为目前的轻节点结构已经是基于利他主义了。在3个月后,客户端可以随机地忘记,以至于例如一个12个月前接触到的状态树对象,还会被25%的节点存储,而且60个月之前的对象还被5%的节点存储。客户端能够尝试使用常规的轻节点协议,来调用这些对象。

2.希望确保特定数据段的可用性客户端可以在状态信道中进行支付。客户端可以设置支付节点的通道,而且在“我放弃0.0001美元,并且默认这笔支付会永远丢失。但是,如果你之后给某个对象提供哈希H,然后我签名,之后这个0.0001美元会到你手上”这种模式下进行有条件支付。这将标志着一个可信的承诺:可能愿意为未来的对象解锁那些资金,档案节点可以进入数以百万计的这样的安排,等待数据请求出现,并成为收入流。

3.我们期望DAPP开发人员能够让他们的用户来随机存储一部分的存储秘钥,在浏览器本地存储中存储与它们的DAPP相关的部分存储密钥。这甚至可以故意在Web3API中很容易做到。

事实上,我们希望能够知道“档案节点”的数量,可以永远存储任何事物,并且持续足够高来服务网络,直到在分片引入之后,整个状态大小超过 1-10兆字节,所以以上所说的可能甚至都不需要。

审核编辑:符乾江

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 智能计算
    +关注

    关注

    0

    文章

    179

    浏览量

    16489
  • 以太坊
    +关注

    关注

    14

    文章

    1838

    浏览量

    32006
收藏 人收藏

    评论

    相关推荐

    迈威通信工业无线客户端:智能制造的高效连接新解法

    随着智能制造的兴起,企业越来越依赖自动化和数字化技术来提高生产效率和灵活性。工业无线客户端作为连接各个设备和系统的桥梁,其重要性日益凸显。通过工业无线客户端,可以实现设备间的实时数据交换和远程监控,从而进一步提升生产过程的智能化水平。
    的头像 发表于 11-22 16:10 163次阅读
    迈威通信工业无线<b class='flag-5'>客户端</b>:智能制造的高效连接新解法

    socket 客户端与服务器的实现

    1. 理解Socket 在计算机网络中,socket是一种通信机制,允许两个程序(一个客户端和一个服务器)通过网络进行通信。在Python中,可以使用 socket 库来创建和管理sockets
    的头像 发表于 11-12 14:30 327次阅读

    NTP网络时间服务器能带同步多少客户端

    NTP网络时间服务器能带同步多少客户端
    的头像 发表于 09-04 10:43 456次阅读
    NTP网络时间服务器能带同步多少<b class='flag-5'>客户端</b>?

    Rambus推出DDR5客户端时钟驱动器

    在追求极致性能与效率的科技浪潮中,Rambus再次引领行业前行,正式宣布推出面向下一代高性能台式电脑与笔记本电脑的DDR5客户端时钟驱动器(CKD)。这一创新举措标志着Rambus将其在服务器领域的先进内存接口技术成功扩展至广阔的客户端市场,为PC用户带来前所未有的性能飞
    的头像 发表于 09-03 15:26 545次阅读

    如果ESP上的TCP客户端与服务器断开连接,如何启用自动重连?

    ESP - TCP 客户端 嵌入式 Linux 服务器 - TCP 服务器 如果ESP上的TCP客户端与服务器断开连接,如何启用自动重连?
    发表于 07-17 06:25

    如何获取连接的TCP客户端的ESPCONN指针?

    我几乎阅读了 SDK API 指南版本 1.0.1 的所有文档 并开始了解如何添加用户 AT 命令。 这真的很简单,只需拨打at_cmd_array_register。 BUT! 如何获取连接的 TCP 客户端的 ESPCONN 指针?
    发表于 07-12 14:54

    如何同时在ESP8266上运行TCP客户端和TCP服务?

    我们是 esp8266 的长期用户,并在该芯片上运行数千台家庭自动化类别的现场设备。然而,一个小小的限制阻碍了我们开发一些更有趣和创新的产品。 要求:我们需要同时运行 TCP 客户端(连接
    发表于 07-08 08:26

    求助,关于ESP32C3 TCP客户端连接断线问题求解

    ESP32C3开启AP模式做TCP服务器,手机做客户端连接服务器;超过默认最大连接数(5)以后,即使有部分客户端断开了,也无法再发起连接连接不上。一定需要服务器给客户端发送数据,确认客户端
    发表于 06-27 07:54

    请问esp32能支持多个客户端同时连接吗?

    根据我现在的测试结果,esp32作为ble server时同时支持一个客户端连接,前一个客户端必须断开蓝牙连接,后一个才能连接。实际esp32能支持多个客户端同时连接吗?有没有相关例程?
    发表于 06-11 06:25

    服务测试和客户端测试区别在哪

    服务测试和客户端测试是软件开发过程中的两个重要环节,它们分别针对服务器客户端的软件进行测试。本文将详细介绍服务测试和
    的头像 发表于 05-30 15:27 3135次阅读

    使用FreeRTOS+LwIP开发版做客户端断开后不能够重新连接?

    请教下, 使用FreeRTOS+LwIP 开发版做客户端断开后不能够重新连接 ? 具体描述如下: 1、开发版作为客户端使用 2、初次上电能够正常通讯,也就是 开发板可以发送数据到服务器
    发表于 04-30 07:48

    stm32 +lwip1.3.1客户端异常导致网络ping不通怎么解决?

    stm32上运行lwip作为服务器,如果客户端异常了,发现在客户端再也ping不通 网络如果异常,交换机挂了,重启后,客户端怎么都ping不通stm32 有没有遇到同样的问题? 不是tcp的pcb被占用,ping都不能通,lw
    发表于 04-22 07:30

    HarmonyOS开发实例:【分布式新闻客户端

    基于栅格布局、设备管理和多端协同,实现一次开发,多端部署的分布式新闻客户端页面。
    的头像 发表于 04-17 15:57 885次阅读
    HarmonyOS开发实例:【分布式新闻<b class='flag-5'>客户端</b>】

    配电网架空线路故障精确定位装置:Web客户端和手机客户端样式

    接下来,深圳鼎信智慧科技跟大家科普配电网架空线路故障精确定位装置的Web客户端和手机客户端样式: 在实际应用中,行波双测距原理具有较高的精度和可靠性,尤其适用于配网架空线路的故障定位。其优点
    的头像 发表于 01-30 17:47 783次阅读

    适用于Linux的基于Rust的同步客户端介绍

    一个简单而优雅的 GUI 同步客户端,提供双向同步。
    的头像 发表于 01-05 11:32 634次阅读
    适用于Linux的基于Rust的同步<b class='flag-5'>客户端</b>介绍