火星链 火星链
Ctrl+D收藏火星链
首页 > Polygon > 正文

CON:我们在以太坊2.0测试网运行了近3000个Validator

作者:

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

编者按:本文来自HashQuark社区,Odaily星球日报经授权转载。Prysm是优秀的ETH2.0的实现,也是目前Medalla测试网上运行最多的实现。Prysm采用BeaconChainNode+ValidatorNode的架构,前者负责同步区块数据,后者负责签名出块和见证。由于ValidatorNode可同时负载多个验证人,为了对其可负载验证人数量以及相关验证人部署步骤有一个定性和定量的认知,我们特安排此次测试。

测试结论

我们复刻了Medalla测试网,搭建HashQuark自己的ETH2.0BeaconChain,进行了两轮测试,一共14个测试用例,跑了数十万计Validator。Prsym的实现非常优秀,对于拥用少量ETH想参与以太坊Staking的普通用户而言,一台4核8G的云服务器就能够平稳地运行BeaconChainNode和Validator,但运行过程中遇到的技术问题都不是非技术人员的普通用户能解决的。对于运行上万个Validator的专业化PoS矿池,需要更高的配置才能保证超高出块率。出块率会随着Validator数量的增加而减少。我们接下来会在公开测试网Medalla进行下一轮测试,以更贴近主网环境,目前我们已经在Medalla正常运行了近3000个Validator,占整个网络的5%。测试环境

我们采用geth来搭建私有ETH1.0网络,与公开测试网Rinkeby或goerli一样,采用‘clique’proof-of-authority算法,因为其相比PoW对资源需求更少。Prysm采用测试时的最新的release版本。以下测试采用的云主机部署,我们选取通用型N机型,CPU平台为Intel/Broadwell。系统采用Ubuntu18.04.2LTS。geth版本为1.9.19-stable,Prysm版本为v1.0.0-alpha.24。第一阶段初步尝试

Tether:我们与Terra完全不同,且拥有足够的储备维持USDT稳定:5月23日消息,Tether官方发文表示,稳定币维持稳定的前提是每一个稳定币均可以固定的价值赎回。而USDT和Terra的设计、机制和抵押品完全不同。Terra是算法稳定币,具有旨在实现稳定的机制,但是最终失败了。相对而言,USDT完全由抵押品支持,每一个USDT均可兑换为1美元。

当交易所的USDT的价格不等于1美元时,只能表明用户对流动性的需求超过了该交易所的订单簿,并不意味着USDT脱锚。Tether拥有超过700亿美元的抵押品,以用于这赎回USDT,满足用户的流动性需求。且可以在几天内完成用户超出流通USDT 10%的赎回请求。

此外,Tether宣布USDT的储备中超过55%是美国国债,商业票据的占比不到29%。[2022/5/24 3:36:53]

测试方案

我们先从不同数量的验证人对服务器资源的压力进行简单测试以获得基本认知。采用最基础的两台ETH1.0节点+两台ETH2.0BeaconChainNode+两台ValidatorNode架构搭建私网作为起始尝试方案。网络稳定运行一天为观察的时间段。测试用例

下表为我们进行测试的概览:

表1测试指标

测试过程中我们收集了各个实例服务器的CPU、内存、磁盘IO、网络带宽IO等指标。测试过程

在测试1中,2核4G的BeaconChainNode内存阶段性上升,在运行约6小时后,内存使用率达到100%,导致进程出现内存不足错误被迫停止,同时CPU使用率也逐步提高。如下图所示:

灰度创始人:漫长的日子里,我们所有人都陷入了黄金行业:灰度创始人Barry Silbert刚刚发推表示,在漫长的日子里,我们所有人都陷入了黄金行业。[2021/5/17 22:09:01]

图1

图2之后,我们提升了BeaconChainNode的配置为4核8G。在实例2-5中,依次提升验证者数量1k-10k来观察服务器CPU、内存、磁盘IO、带宽等指标数据,均无压力,也没有异常。之后我们在不同地区部署ETH2.0节点,来观察不同地区的网络互联情况是否会对各指标产生较大影响,实验结果均无异常。测试小结

根据私网测试情况来看,BeaconChainNode建议4核8G配置,Validator节点2核4G的配置够用,但是在导入key文件时会占用1核CPU,该CPU占用率为100%,稳妥起见,建议4C6G的配置。

图3此外,在本阶段的测试中,对磁盘的I/O性能和外网带宽要求很低,可能是由于私网的原因,具体的对应的性能要求还需要在ETH2.0官方测试网中进行测试。第二阶段对比测试

测试方案

第一阶段主要测试了不同数量的验证人对于服务器资源的压力,此外,验证者的出块和见证也是也是对于验证人很重要的指标。为此我们进行了对比测试。在同一个网络中,将不同数量的验证人部署在不同的地区来进行对比测试。测试指标

BM:比特币将我们从不可控制和不可持续的政府开支中解放出来:今日,EOS创始人Daniel Larimer(BM)在J.K.罗琳请教比特币的推特下回复称,比特币是一种诚实的货币,它的货币政策是固定和有限的发行。它将我们从不可控制和不可持续的政府开支中解放出来。控制货币发行的人拥有整个世界,他可以在市场上免费购买任何资产。[2020/5/16]

测试过程中我们将收集各个实例服务器的CPU、内存、磁盘IO、网络带宽IO、应出的块数、实际出块数、应该见证的块数、实际见证的块数等指标。测试用例

以下为我们的测试用例:

表2ETH1.0网络由三台2核4G云服务器组成,两台位于香港,一台位于圣保罗。出块时间设置为15s。我们分别在香港、新加坡、洛杉矶、法兰克福、圣保罗、伦敦六个地区部署了BeaconChainNode和ValidatorNode。各个地区的BeaconChainNode和ValidatorNode通过内网连接。配置和相应的验证人数量如上图。实例1和实例2都是1k验证人,区别在于ValidatorNode的配置,用于对比不同配置的验证人数量对指标的影响。实例3,4,5,6增加了验证人数量。鉴于实际情况下我们不太可能将超过10k的验证人置于单台机器上,因此我们将测试数量停在了20k。各个地区的BeaconChainNode与其余node相连。测试网参数选择

我们先在ETH1.0网络上部署了deposit合约,生成所需数量的验证人密钥后,批量发送了存款交易。Prysm启动时修改了以下参数:MinGenesisActiveValidatorCount设置为8192,由于我们的测试中包含了40k验证人,所以能够满足;Eth1FollowDistance设置为20,也就是ETH1.0网络上的存款合约在5分钟后会被ETH2.0网络监测到;SecondsPerETH1Block设置为15,这与ETH1.0网络每个块时间设置的一致;MinGenesisTime设置为1599811200,也就是说最早在2020-09-11T16:00:00+08:00启动。实际上,由于我们事先发送了所有的存款交易,满足最早启动时间设置的最小验证人数量,整个ETH2.0网络在1599811207(2020-09-11T16:00:07+08:00)启动。数据统计和测试结果

声音 | BB:我们正在全面重建数字基础设施:Block.one首席执行官Brendan Blumer发推称:“为SergMetelin以及我们伟大的开发者关系团队自豪,他们一直在努力地将EOSIO的前沿创新与开发人员的实际需求联系起来,并基于社区反馈提倡内部改变。”有人评论道:“EOSIO现在能为这个世界做什么?”

BB回复称:“EOSIO数据库透明性、安全性和完整性的新基础增强了您的创造力和想象力。更难回答的问题是,什么东西不能从如此强大的原则中受益?我们正在全面重建数字基础设施。”(MEET.ONE)[2020/1/31]

我们额外部署了一个BeaconChainNode来连接到ETH2.0私有网络,来查询数据。加上--slots-per-archive-point=1的参数来持久化存储每个区块的数据,从而加快查询速度。加上--rpc-max-page-size=1000的参数,使得我们每次可以查询更多的数据,从而减少请求次数加快总体速度。我们选取了网络相对稳定的一段时间,从75epoch到1200epoch采样,获取这段时间内处于不同实例中验证者的出块和见证的数据加以分析,得出如下结果:所有验证人都成功出块,无漏块情况;不同地区的验证者见证情况略有差异:

表3这里我们定义见证率为在一段时间内被包含的见证数除以被分配到见证数。不难看出,总体来说,随着验证人数量的上升,见证率会下降。但在实例3中,虽然验证人只有2k,但见证率却比6k甚至10k的见证率都要低。为了探究导致实例3总体见证率异常的原因,我们统计每个实例里验证者的见证率加以分析,看是否由于个别验证者出了问题拉低总体比例。我们将每个验证者比例按照范围划分,得到以下数据:

世界最大ATM运营商Cardtronics:加密货币对我们的业务构成威胁:世界最大ATM运营商Cardtronics在10-K年度报告中表示,虚拟货币是该公司面临的众多威胁之一。报告表示消费者行为分析显示,更好的支付方式发生了重大变化。现在,更多的客户选择电子支付方式,而不是传统的实物纸币。该公司认为,比特币等虚拟货币可能是导致普通民众对现金需求减少的原因,所有这些因素加起来会对ATM交易量产生负面影响。[2018/3/3]

表4由于各个实例验证人数量不同,换算成比例会更加直观:

表5可以看到,实例3中大多数验证人的见证率都不高,这也意味着实例3应该出了问题。为此,我们检查了实例3的日志,发现BeaconChainNode与其它节点以及ETH1.0的连接并不稳定,猜测是由此导致了见证率的异常,有待后续检验。服务器压力

在本轮测试中,我们观察到如下表的性能指标数据:

表6BeaconChainNode实例1-5中,BeaconChainNode的CPU使用率在5%-10%之间,实例6的BeaconChainNode的CPU使用率约为12%。内存方面呈现平稳增加,在12%-17%之间,磁盘IO与带宽无明显差异。ValidatorNode随着验证者数量的增加,ValidatorNode的各项指标均平稳增多,可以看到,磁盘IO与带宽基本上正比于验证者的数量。此外,生成验证者密钥文件方面,我们采用的是一个推荐的python命令行工具,该工具生成密钥的效率相对不高,在多核的机器上只占用1核,生成2000个密钥对需要2.5小时左右。另一方面,ValidatorNode导入密钥对也是单核执行,导入2000个密钥对的时间大约为40分钟。测试小结

通过本轮测试,我们在私有网络中观察到,验证人数量的增加会影响节点上所有验证人的出块率,对于单个验证人来说,在最好的情况和最坏的情况下,平均每天少见证约10个块。出块方面在我们的测试中并未发现不同。内存与磁盘IO的使用率相对于CPU和带宽,更加明显地随着验证人数量的增加而提升。后续测试方案和待优化步骤

在本轮测试中,以下几方面占据较多的准备时间:验证者密钥对生成部署deposit合约ValidatorNode导入密钥对在后续方案中,计划对上述步骤采取优化,提高测试效率。此外,在后续测试计划中,考虑到不同地区的网络之间的稳定性及其对验证人指标的影响,可以考虑以下几点改进:在同一地区增加多个测试实例,来对比是否为地区造成的差异;部署多个ETH1.0节点,使BeaconChainNode能够畅通连接ETH1.0网络,减少造成的影响;增加单独同一地区对比测试,增加验证者数量,控制变量,单纯比较验证者数量的影响。在统计数据方面,考虑增加更多维度,如考虑到见证被包含的距离等,可参考这篇关于见证效率的文章。测试问题汇总

GRPC数据量超过默认大小当增加到近4k验证人时,ValidatorNode会报错grpc获取的消息大小5350532(5M)超过最大值4194304。

图4解决方案:启动ValidatorNode时通过--grpc-max-msg-size参数将grpc允许的消息大小适量调大。Beaconchainnode无法同步进行第一轮测试时,在网络中只存在两个BeaconChainNode的情况下,容易出现两个节点之间无法同步区块的问题,两个节点都不认为对方是合适的peers。如下图所示:

图5解决方案:我们目前采用清除节点的数据重新同步来解决。测试中我们发现,随着BeaconChain节点的数量增多,该问题便不再发生。存款金额误报不够如发生下述计算activeEpoch过大或存款金额不够而实际已够的情况,则表示Prysm实现存在问题,参考这个issue,该问题已在编写本报告的最新版本修复。

图6

标签:ODENODEETHCONLODEAgricoin MasternodeVETH币Conscious Value Network

Polygon热门资讯
SUB:一文了解Polkadot生态中的智能合约

Polkadot是基于Substrate区块链开发框架开发的异构多链系统,Substrate为开发区块链提供了必要的基础功能模块,开发者可以使用Substrate为特定业务搭建平行链.

1900/1/1 0:00:00
ASI:读懂哈希率「炼金术」:加密货币算力市场反身性与四季更迭

编者按:本文来自链闻ChainNews,星球日报经授权发布。撰文:LeoZhang与KarthikVenkatesh,分别为算力及衍生产品研究机构AniccaResearch创始人与数据分析师当.

1900/1/1 0:00:00
以太坊:为什么说以太坊的DeFi生态才是王者

今天在网上看到近日币安的联合创始人何一近期接受的一次视频采访,谈DeFi、谈币安的智能链。何一对币安智能链抱有很大的期望,并说希望币安智能链最终能在生态上超过以太坊的DeFi.

1900/1/1 0:00:00
COIN:GameFi新玩法:社交代币COIN与背后「E-Den辛迪加」崛起

编者按:本文来自链闻ChainNews,星球日报经授权发布。相信你和我一样没听说过玛格丽特·德库尔塞这个人,但她其实在加密艺术领域里赫赫有名,并用笔名「CoinArtist」发表了一系列作品.

1900/1/1 0:00:00
CER:CertiK:Soda项目智能合约安全漏洞分析

判断一个人到底属于什么资产阶级,只需要看他的负债率。简而言之,借的钱越多,代表你越有钱。所以借钱从某种角度上来讲,是属于富人的游戏。通过借贷手段合理分配资产从而达到收益也是理财的精髓.

1900/1/1 0:00:00
MAKE:MakerDAO「3.12」清算赔偿投票结束,65%的投票者支持「0赔偿」

编者按:本文来自区块律动BlockBeats,Odaily星球日报经授权转载。9月24日,根据9月23日晚结束的投票,MakerDAO将不会赔偿3月12日「黑色星期四」闪电崩盘的受害者,据此前报.

1900/1/1 0:00:00