大约5年前,我们开始构建Trinity——以太坊网络上的新型“轻量级客户端”。那时候Geth刚刚发布了第一版LES协议,而我们曾心怀远大的梦想。
远大的梦想往往被现实所击倒。这些年来,我们得到了一些教训:
EVM计算从根本上来说是“繁重的”。
LES如同茫茫沙漠,客户端就是沙漠中渴求数据的旅人。
同步并维护状态的难度过高。
区块链上的历史记录在绝大多数情况下是无用的,却是必不可少的。
核心以太坊协议在本质上对“轻量级”不友好。
Python太慢了。
我们的目标是远大的,方法是有缺陷的。现在是该从头再来的时候了。
访问以太坊协议
如果你想要与以太坊协议交互,摆在你面前的是两个选择:
自己运行客户端。
国务院:推进科普与区块链技术深度融合:为贯彻落实党中央、国务院关于科普和科学素质建设的重要部署,依据《中华人民共和国科学技术进步法》、《中华人民共和国科学技术普及法》制定《全民科学素质行动规划纲要(2021-2035年)》,其中要求实施智慧科普建设工程。推进科普与区块链等技术深度融合,强化需求感知、用户分层、情景应用理念,推动传播方式、组织动员、运营服务等创新升级,加强“科普中国”建设,强化科普信息落地应用,与智慧教育、智慧城市、智慧社区等深度融合。(新华社)[2021/7/10 0:40:52]
使用Infura等中心化提供商的服务。
上述两个选择可以满足大多数用例的要求,但是它们位于两个极端。以太坊客户端需要消耗大量磁盘空间,花费数小时乃至数天时间进行同步,而且对CPU和内存的占用通常很大。中心化提供商是一种简单可靠的方案,但是要以牺牲隐私性、安全性和去中心化原则为代价。
动态 | 币安科普MimbleWimble算法:币安官方推特今日发布隐私算法Mimblewimble的科普贴,在下方留言区大量网友留言猜测是否是基于 Mimblewimble算法的隐私币Grin或者Beam即将登陆币安交易所,其中猜测Grin的呼声更高。[2019/9/2]
为什么我们不能有介于二者之间的第三种选择?互联网已经证明过很多次了了,在困难模式和简单模式之间,人们往往会选择后者。
自己托管邮件vs.Gmail
购买DVD或CDvs.盗版
盗版vs.流媒体
自己运行以太坊节点vs.Infura
我想过采用隐私保护型解决方案。然而,我的所有交易都是通过MyCrypto或Metamask完成的。这两款钱包都来自中心化提供商。它们都支持用户使用自己的节点,但是就现有的客户端来说,我认为这么做成本太高。如果我们想与这些中心化解决方案争夺市场份额,我们需要为用户提供更好的选择。
声音 | 火星人朋友圈科普RAM:火星人在朋友圈发文称,“什么是RAM?简单来说就是EOS这个国家的土地,所有的经济行为都离不开土地。只要EOS的BP们能投票形成一个稳定的供给预期,并且不改变目前的Bancor算法,那么RAM后续的价格有可能会像北上广深的房价走势。房价下跌不行,房价过快上涨也不行,EOS的生态越来越像某国了,真有意思。”[2018/7/6]
我们对客户端的要求是:
能够在资源有限的设备上运行
公开标准“钱包”应用所需的API
不需要同步
从用户的角度来说,我希望让客户端时刻保持运行,而不会影响我的设备的性能。我希望在离线一段时间后,再上线时无需等待客户端同步。
这就是我心中的“圣杯”,是我舍命也要攀登的高峰。
钱包
我们这里讲的是如何为钱包构建一个完美的客户端。钱包无处不在,而且主要由中心化提供商支持。总的来说,钱包要满足以下需求:
财政部副部长朱光耀:数字经济还处在发展的过程中,要以科普、推动的态度来推进数字经济发展:今日,在中国发展高层论坛2018年会上,财政部副部长朱光耀表示:“数字经济还处在发展的过程中,要以科普、推动的态度来推进数字经济发展。也要关注数字经济的其他影响,包括税收征管、反监管措施等要跟上。”[2018/3/25]
追踪区块链的最新区块
查看账户余额和nonce
读取合约信息
估算交易的gaslimit
发送交易
监控需要打包的待处理交易
大多数钱包都采用标准化的JSON-RPCAPI。根据上述需求转化成的JSON-RPC端点如下所示:
eth_blockNumber用来追踪链首块
eth_getBalance和eth_getTransactionCount用来查看账户信息
eth_call用来读取合约信息
eth_estimateGas用来估算gaslimit
eth_sendRawTransaction用来发送交易
eth_getTransactionReceipt表示交易已经被挖出
如果我们更深入分析该功能的必备条件,就会得到更低一级的需求:
访问账户和合约存储以支持eth_call、eth_estimateGas、eth_getBalance和eth_getTransactionCount
访问gossip网络来追踪链首块和eth_sendRawTransaction
访问链上历史记录来获得eth_getTransactionReceipt
因此,如果我们可以满足这些需求,就可以构建一个适合轻量级钱包的客户端,不需要同步,也无需牺牲隐私性和安全性。
如今的以太坊网络
目前,以太坊客户端可以在以太坊协议和LESDevP2P协议之间进行选择。
LES协议采用服务器/客户端模型。在该模型中,数据会根据要求从服务器流向客户端。该协议不允许客户端通过任何有意义的方式返回数据,这点可以从协议状态看出。根据我的经验来看,LES协议中的服务器和客户端在数量上严重失衡。运行服务器的成本很高,现有服务器的数量不足。这就导致LES变得不可靠,而且经常会变得完全不可用。
以太坊协议则另有缺陷。该协议很好地达到了目的,确保网络中所有的节点都尽可能地复制了完整的历史记录和状态数据。这对客户端的要求很高。网络中的每个节点都必须保存完整的历史记录和状态。没有保存这些数据的节点不太可能保持健康的点对点连接,可能会在无法满足对等节点的数据要求时断开连接。
在本系列文章中,我们想要解构以太坊协议这一“庞然大物”。该协议包含了我们理想的客户端类型的所必备的一切功能。它的设计适合全节点和矿工,但是不适合我们所概述的轻量级客户端。
解构以太坊协议
让我们将目光转向以太坊协议……
我们需要解决这个问题。在与以太坊协议交互时,人们可选择的方式有限,而且高度依赖中心化提供商。当前的网络状态就预示了未来可能发生的情况。
我们构想了另一种适用于以太坊钱包的轻量级客户端。这一构想不只是一个想法,而是以实验、原型以及我们对现有协议不断深入的认知为基础的。
我们正在研究的解决方案需要对核心以太坊协议进行一些修改,以便支持该用例。在该系列的下一篇文章中,我将概述需要修改和新增的部分,以及我们计划如何去实现它们。最重要的是,我将讲述我自己对这一新型轻量级客户端的用户体验的期望。
原文链接:https://snakecharmers.ethereum.org/the-winding-road-to-functional-light-clients/作者:PiperMerriam翻译&校对:闵敏&阿剑
来源/LongHash 自2017年1月以来,比特币已经走过了一段漫长的道路。当时,每枚比特币的价格远低于1000美元——相比之下,截至1月21日,其价格为30000美元左右.
1900/1/1 0:00:002020年,被寄予厚望的存储类挖矿并没有如人们预料一般引爆市场,但因此而引发的关于PoC的讨论则始终没有停止.
1900/1/1 0:00:00来源:中新网中新社北京1月23日电(刘亮)欧洲中央银行本周透露,最早或于今年4月决定是否继续推进数字欧元的筹备工作。这也是继去年发布数字欧元报告后,欧洲央行再次对数字化货币的推进表态.
1900/1/1 0:00:00原标题:Tellor的Chorus预言机协议Tellor最近发布了其Chorus的计划。简单来说,Chorus是社区货币协议.
1900/1/1 0:00:00本文来自?CryptoNewsFlash,作者:JakeSimmons译者:Odaily星球日报余顺遂摘要:在韩国,XRP交易量仅次于比特币;与西方国家相比,DeFi市场在韩国没有那么受欢迎.
1900/1/1 0:00:00以下内容数据来自KingData,转发、引用请注明数据源为KingData。KingData用数据赋能交易,快人一步遇见财富.
1900/1/1 0:00:00