SON:Fluffy 客户端:以太坊的极轻客户端

我们该如何设计网络,才能让客户端只需为网络贡献少量数据,就让整个网络具有很大的意义呢?

——PiperMerriam

我们很高兴地宣布,Nimbus将加入以太坊基金会的“门户网络”团队,作为门户网络的启动客户端之一。

一句话总结:“门户网络”?是一个开发中的跨客户端项目,为的是重新构想以太坊的轻客户端,并开发出一套可用且实用的轻客户端体验。

直接引用这份规范的表述:

“门户网络”是一个还在开发的项目,为了让资源有限的设备也能轻量地访问协议。

“门户”一词的含义是,这些网络可以观察到协议运行的现状,但对核心的以太坊协议的运行又无关紧要。

门户网络将由一个或多个去中心化的点对点网络组成,这些网络共同提供暴露标准的JSON-RPCAPI所需的数据和功能.

这些网络是经过专门设计的,为了保证参与这些客户端只需付出最小化的网络带宽、CPU、RAM和机械硬盘资源即可加入。

“门户网络”一词也用来描述参与这些网络并暴露标准的JSPN-PRCAPI的软件.

特别地,我们的目标是与EF一道,围绕已有的以太坊协议,开发出一组新的以太坊协议,能专门服务于这种获取以太坊数据的新方法。

P网Poloniex 投资人孙宇晨:P网Poloniex 致力于打造“币圈高盛”:8月7日,P网Poloniex 在深圳南山区华侨创意园举办中国首次见面会。P网Poloniex 投资人孙宇晨表示:P网Poloniex 是华尔街首批合规交易平台,曾接受知名投资银行高盛集团的投资,后接受自己本人投资。P网Poloniex 致力于打造币圈高盛,为整个行业投资人提供华尔街般的投资体验。

据了解,P网Poloniex成立于2014年,是注册于塞舌尔的一家全球化数字资产交易平台,自P网Poloniex创立以来,安全高效的服务便得到用户的认可,真实交易量长期位列全球TOP3,独创的TrollBox系统让用户获得更有趣的交易体验。[2020/8/7]

总体目标是为以太坊提供一个操作模式,能够服务于常见的使用模式,而不是实时追踪完整的状态。

我们正在讨论要开发的是一个用于钱包的完美客户端,一个极轻客户端,可以给网络作贡献,但又不要求同步区块链。

这也没有听起来那么困难。我想象大部分钱包都直接嵌入轻客户端,比如?@ethstatus?将集成一个?@ethnimbus?轻客户端。所以可能出现这样一种情况:大部分用户都在不知不觉中就开始运行轻客户端了。

独家 | 币圈惊现“老鼠会” RatScam敛财比F3D更简单粗暴:继区块链项目评级机构RatingToken对庞氏游戏Fomo 3D(以下简称F3D)进行跟踪报道之后,目前市面上又出现了一系列以“Rat(老鼠)”命名的山寨合约。

与其他山寨合约一样,Rats系列也隐藏着不少安全隐患。以RatScam为例,RatingToken智能合约机器检测得分仅为2分,共存在16个可疑风险漏洞。而且从游戏主体部分的规则来看,RatScam几乎是F3D的“阉割版”:游戏只有1轮,而不像F3D理论上会一直进行下去;RatScam中团队分成高达10%,而F3D仅为2%。

另据RatingToken团队深入调研发现,RatScam还在Facebook上进行了广告投放,可见团队资金实力雄厚,是一次有备而来的圈钱行动。目前官网显示RatScam奖金池已有567.5348 ETH,RatingToken在此提醒各位注意防范风险,谨慎投资。[2018/7/27]

May24,2021

因此,我们的一个最终目标是,将这种客户端直接敲入到Statusapp中。

它有潜力能提升我们用户的安全性和隐私性,同时提高以太坊的可靠性,因为更多用户可以为网络的健康作贡献。

放弃职业体育投身币圈,洛杉矶道奇队退役球星创立加密货币对冲基金BlockTerra Capital LLC:年仅22岁的洛杉矶道奇队小联盟棒球明星Tyler Adkison已经退役,创立加密货币对冲基金BlockTerra Capital LLC。虽然最近加密货币市场表现极不稳定,但Adkison却依然对未来非常有信心。现在,这家对冲基金已经获得了投资人和30名棒球和橄榄球运动员客户,其中还包括波士顿红袜队明星投手乔·凯利(Joe Kelly)。[2018/4/10]

背景

门户网络根植于开发者PiperMerriam以及Trinity团队的初始目标:在现有的网络上开发一个轻量级的客户端。它的诞生是因为他们意识到了,现有的网络对于他们所设想的客户端类型来说不够灵活。

用Piper的话来说:

当我们开始开发Trinity客户端时,我们的目标是开发一个轻量级的客户端。但花了接近三年时间深入了解协议、探索开发我们所设想的客户端的途径之后,我们最终得出一个结论:它在现有的网络上是做不出来的。

这就是门户网络的初衷。我们要回到我们想要的客户端形态,然后设计出其运行所必需的网络功能。

Conflux网络第一阶段上线:据官方消息,4月27日,Conflux网络第一阶段正式上线。本阶段,Conflux将为网络生态中的应用提供稳定、安全的测试环境。第一阶段上线,意味着用户可以正式参与并体验到Conflux高性能底层网络及生态服务。首款基于Conflux网络开发的去中心化交易应用MoonDEX ,也于今日正式开始公测。

Conflux 网络第一阶段的重要意义在于提供一个稳定的底层网络环境,供Conflux生态之上的合作伙伴测试开发DApp。除去已经落地的DEX应用及DEX生态之外,Conflux 也将从资源、资金、团队等层面大力扶持各领域DApp的发展。[2020/4/27]

Trinity客户端不会再开发下去了,我们正在开发一个独立的门户客户端,叫做“Trin”,用Rust语言编写,将是门户网络的启动客户端之一。

动机

现有的DevP2PLES网络在设计上采用了客户端/服务器架构,轻客户端作为客户端,而全节点作为服务器端。

因为这种架构把所有的负载都交给全节点来承担,而全节点的运营成本已经很高了,所以节点运营者就不愿意打开这个功能。

所以,虽然当前的网络设计很好地实现了其初始目标,但从轻客户端的视角来看,它是严重的失败。

动态 | 电商初创公司Flubit.com允许用户使用加密货币支付享受25%折扣:据Zycrypto消息,电商初创公司Flubit.com表示,用户现在可以在使用平台的本地加密货币MonetaryUnit(MUE)时购买商品享受高达25%的折扣,包括视频游戏,笔记本电脑,美容产品等。[2019/2/16]

我们如何解决这个问题呢?就像Piper的Trinity团队发现的那样,现实表明这个问题没有简单的解决方案。现有的网络不够灵活,无法做出高效的轻客户端设计。

修复这个问题需要我们回到一张白纸,重新设计协议的核心。

设计

一个轻客户端友好的网络,必须设计得节点只需付出少量存储空间、少许工作量,就能参与网络并为网络做贡献,而不是要求每个节点都必须承担很高的负载。

换句话来说,这样一个网络必须允许轻客户端在实际上为网络做出贡献,使得每当有额外的客户端加入网络,都会增强网络的容量。

具体来说,这意味着要提出一种网络设计,可以减少你的偶发请求的数据的验证开销,并降低在网络中传递消息的基本开销。

门户网络的目标是通过将以太坊协议的整体结构为三个独立的网络:Gossip状态以及历史,来实现这一点;最开始的开发重心是状态网络。

这些网络将与ETH协议共存——但不像ETH协议,它们不必是完全无懈可击的,但它们需要能?几乎?不间断工作。

愿望是这些新的网络,可以随着时间的推移,与现有的网络更加紧密地结合在一起。举个例子,我们可以设想这样一个世界:全功能客户端可以使用历史门户网络来为节点运营者提供额外的选择,仅存储他们关心的历史而不是整条区块链。状态数据也是如此。

总而言之,这个模块化的架构——其中数据以P2P的模式来分享,而事务和区块则靠gossip来传播——使得轻客户端可以自己选择存储/服务多少状态数据和历史数据。

当他们需要访问本地没有的数据时,他们可以在相关网络提出adhoc请求。

JSONRPC备注

借用Piper的精彩文章“设计可用的轻客户端part1”:大部分钱包,包括我们的,在?JSONRPC?API上都是标准化的.

Status钱包的正确运行需要下列?JSONRPC?端点:

eth_blockNumber?用于跟踪链的顶端

eth_getBalance?以及?eth_getTransactionCount用于获得账户信息

eth_call?用于读取合约信息

eth_estimateGas?以及?eth_gasPrice?用于估计gas费

eth_sendRawTransaction?用于发送用户的交易

eth_getTransactionReceipt?在交易上链后获取回执

如果我们进一步梳理实现钱包功能的必要组件,我们可以得到如下更底层的需求:

访问账户以及合约存储项,以支持:eth_call、eth_estimateGas、eth_getBalance?以及?eth_getTransactionCount

访问gossip网络以跟踪链的顶端以及?eth_sendRawTransaction

访问链的历史,用于?eth_getTransactionReceipt

若可开启对状态、Gossip和历史的轻量级访问,门户网络就打开了可嵌入钱包的轻客户端的大门,它们可以满足这些需求,而且不需要同步区块链,也不必牺牲隐私性和安全性。

这对现状来说是个很大的提升,现在我们不得不依赖于Infura来发起确定的JSONPRC调用并发送交易——无法访问状态,我们就无法服务大部分JSONPRCAPI,也无法发送交易,因为我们无法参与交易gossip。

项目现状

我们已经开始为Nimbus开发一种操作模式,一开始命名为?nlpn?,但现在重命名为?fluffy?,会与以太坊1的客户端同时存在、运行。

fluffy?将使?nimbus-eth1?客户端可以作为网络中的一个极轻客户端节点来运行。

初步的工作是开发?PortalWire协议,这是一个建立在NodeDiscoveryv5.1协议基础上的次级协议。

我们已经实现了对该协议的基本支持,并且几周以前,我们就已成功实现了与其它客户端的握手,包括?ddht客户端和Trin客户端。

下一步

下一步是通过PortalWire协议来传输数据。我们正在处理状态数据。

这需要“桥节点”为门户网络输入状态数据。当前的措施是使用一个Nethermind客户端插件作为定制化?JSON-PRC?API来给愿意充当桥节点的门户节点提供数据。这一工作已经开始。

最终我们的极轻客户端将支持以太坊?JSON-PRC?API的一个子集,所以钱包可以直接集成这种客户端。

资源

Nimbus门户网络客户端可以在我们的nimbus-eth1代码库中找到:?https://github.com/status-im/nimbus-eth1/tree/master/fluffy

PortalWire协议已加入?nim-eth?代码库,作为节点发现协议v5.1的次级协议:https://github.com/status-im/nim-eth

规范:https://github.com/ethereum/stateless-ethereum-specs/

网站:https://www.ethportal.net/

一些有关与ddht和trin的第一次PortalWire协议测试的资料:https://gist.github.com/kdeme/36795f5deae7d02ce1785e9c7d501e53

PiperMerriam撰写的系列博文:Thewindingroadtofunctionallightclients

有关这个主题的一个视频演讲

注:方便的是,所有实现功能性轻客户端所必须的基础设施也会自然延伸到无状态客户端上,所以会跟无状态以太坊有很多交叉。实际上,让无状态客户端能够服务于绝大部分?JSON-PRC?API是门户网络的诸多动机中最核心的一个。

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

链链资讯

[0:46ms0-3:903ms