遍历eth密钥
1. 我知道以太坊(ETH)的地址和助记词,怎么把里面的ETH转出来
你是要转到哪里去呢?钱包还是交易所
转ETH,只要有地址,就可以转出去了
助记词是当你的密钥忘记了,可以协助找回来的东西,并不跟提币相关。
2. 以太坊源码分析--p2p节点发现
节点发现功能主要涉及 Server Table udp 这几个数据结构,它们有独自的事件响应循环,节点发现功能便是它们互相协作完成的。其中,每个以太坊客户端启动后都会在本地运行一个 Server ,并将网络拓扑中相邻的节点视为 Node ,而 Table 是 Node 的容器, udp 则是负责维持底层的连接。下面重点描述它们中重要的字段和事件循环处理的关键部分。
PrivateKey - 本节点的私钥,用于与其他节点建立时的握手协商
Protocols - 支持的所有上层协议
StaticNodes - 预设的静态 Peer ,节点启动时会首先去向它们发起连接,建立邻居关系
newTransport - 下层传输层实现,定义握手过程中的数据加密解密方式,默认的传输层实现是用 newRLPX() 创建的 rlpx ,这不是本文的重点
ntab - 典型实现是 Table ,所有 peer 以 Node 的形式存放在 Table
ourHandshake - 与其他节点建立连接时的握手信息,包含本地节点的版本号以及支持的上层协议
addpeer - 连接握手完成后,连接过程通过这个通道通知 Server
Server 的监听循环,启动底层监听socket,当收到连接请求时,Accept后调用 setupConn() 开始连接建立过程
Server的主要事件处理和功能实现循环
Node 唯一表示网络上的一个节点
IP - IP地址
UDP/TCP - 连接使用的UDP/TCP端口号
ID - 以太坊网络中唯一标识一个节点,本质上是一个椭圆曲线公钥(PublicKey),与 Server 的 PrivateKey 对应。一个节点的IP地址不一定是固定的,但ID是唯一的。
sha - 用于节点间的距离计算
Table 主要用来管理与本节点与其他节点的连接的建立更新删除
bucket - 所有 peer 按与本节点的距离远近放在不同的桶(bucket)中,详见之后的 节点维护
refreshReq - 更新 Table 请求通道
Table 的主要事件循环,主要负责控制 refresh 和 revalidate 过程。
refresh.C - 定时(30s)启动Peer刷新过程的定时器
refreshReq - 接收其他线程投递到 Table 的 刷新Peer连接 的通知,当收到该通知时启动更新,详见之后的 更新邻居关系
revalidate.C - 定时重新检查以连接节点的有效性的定时器,详见之后的 探活检测
udp 负责节点间通信的底层消息控制,是 Table 运行的 Kademlia 协议的底层组件
conn - 底层监听端口的连接
addpending - udp 用来接收 pending 的channel。使用场景为:当我们向其他节点发送数据包后(packet)后可能会期待收到它的回复,pending用来记录一次这种还没有到来的回复。举个例子,当我们发送ping包时,总是期待对方回复pong包。这时就可以将构造一个pending结构,其中包含期待接收的pong包的信息以及对应的callback函数,将这个pengding投递到udp的这个channel。 udp 在收到匹配的pong后,执行预设的callback。
gotreply - udp 用来接收其他节点回复的通道,配合上面的addpending,收到回复后,遍历已有的pending链表,看是否有匹配的pending。
Table - 和 Server 中的ntab是同一个 Table
udp 的处理循环,负责控制消息的向上递交和收发控制
udp 的底层接受数据包循环,负责接收其他节点的 packet
以太坊使用 Kademlia 分布式路由存储协议来进行网络拓扑维护,了解该协议建议先阅读 易懂分布式 。更权威的资料可以查看 wiki 。总的来说该协议:
源码中由 Table 结构保存所有 bucket , bucket 结构如下
节点可以在 entries 和 replacements 互相转化,一个 entries 节点如果 Validate 失败,那么它会被原本将一个原本在 replacements 数组的节点替换。
有效性检测就是利用 ping 消息进行探活操作。 Table.loop() 启动了一个定时器(0~10s),定期随机选择一个bucket,向其 entries 中末尾的节点发送 ping 消息,如果对方回应了 pong ,则探活成功。
Table.loop() 会定期(定时器超时)或不定期(收到refreshReq)地进行更新邻居关系(发现新邻居),两者都调用 doRefresh() 方法,该方法对在网络上查找离自身和三个随机节点最近的若干个节点。
Table 的 lookup() 方法用来实现节点查找目标节点,它的实现就是 Kademlia 协议,通过节点间的接力,一步一步接近目标。
当一个节点启动后,它会首先向配置的静态节点发起连接,发起连接的过程称为 Dial ,源码中通过创建 dialTask 跟踪这个过程
dialTask表示一次向其他节点主动发起连接的任务
在 Server 启动时,会调用 newDialState() 根据预配置的 StaticNodes 初始化一批 dialTask , 并在 Server.run() 方法中,启动这些这些任务。
Dial 过程需要知道目标节点( dest )的IP地址,如果不知道的话,就要先使用 recolve() 解析出目标的IP地址,怎么解析?就是先要用借助 Kademlia 协议在网络中查找目标节点。
当得到目标节点的IP后,下一步便是建立连接,这是通过 dialTask.dial() 建立连接
连接建立的握手过程分为两个阶段,在在 SetupConn() 中实现
第一阶段为 ECDH密钥建立 :
第二阶段为协议握手,互相交换支持的上层协议
如果两次握手都通过,dialTask将向 Server 的 addpeer 通道发送 peer 的信息
3. 以太坊简介
如何购买ETH?
如何用信用卡/借记卡购买ETH?
币安(以货币兑换为例)允许您通过浏览器无缝购买ETH。操作步骤:
也可以在P2P市场买卖ETH。你可以通过移动使用程序山念Coin向其他用户购买代币。操作步骤是:
与比特币不同,以太坊不仅用于加密货币网络。它还可以用来构建去中心化的使用,以太作为一种可交易的令牌,已经成为生态系统的燃料。所以以太的主要功能是为以太坊网络提供电力。
不仅如此,以太还可以像其他传统货币一样用来购买商品和服务。
零售商接受乙醚作为支付方式的热图
人们可以使用以太坊的原生货币ETH作为数字货币或抵押品。也有人把ETH看成和比特币一样的价值存储手段。但它不同于比特币,因为以太坊区块链的高度可编程性赋予了ETH更多的效用。也意味着以太成为去中心化金融使用、去中心化市场、交易所、游戏等使用的活力之源。
ETH不基于任何银行,也就是说你会对自己的资金负责。你可以把代币存放在交易所或你自己的钱包里。但是要记住,当你为了自保而使用钱包的时候,一定要妥善保管助记符,这样当你失去钱包的存取权的时候,你就可以追回你的钱了。
一旦数据被添加到以太坊区块链,它几乎不能被更改或删除。这意味着在交易固定之前(交易指令发出之前),必须仔细核对要发送的资金目的地址和金额。大额汇款的时候,最好是小额汇款到地址进行地址确认。
由于智能合约被黑,以太坊为了逆转恶意交易,在2016年被迫硬分叉。但是,这种反转只是特殊事件的极端措施,并不是常态。
所有加入以太坊区块链的交易对公众都是可见的。即使以太坊地址上没有显示你的真实姓名,观察者也会通过其他方法确定你的身份。
由于ETH不是一个稳定的资产,它可能会给你带来收益和损失。有些人选择长期持有以太,赌网络将来会成为全球可编程的结算层。还有的选择用乙醚与其他Altcoins(假币)交易。这两种策略也有各自的财务风险。
作为分散金融(DeFi)的主要支柱,ETH也可以用于借贷,作为贷款的抵押品,铸造合成资产,或作为未来的赌注。
一些投资者可能会长期投资比特币,他们的投资组合中不包含其他数字资产。有些投资者更加灵活,在投资组合中混合使用ETH和其他假币,或者使用一定比例的资金进行短线交易(例如日内交易或摇摆交易)。市场上没有万能的赚钱方法,每个投资者都要根据自己的实际情况选择最适合自己的策略。
目前市面上代币的存储方式有很多种,每种方式都有其优缺点。就像其他有风险的事情一样,最好的选择方式就是在可用的选项中进行多元化的选择。桐核
通常,存储解决方案要么是托管的,要么是非托管的。托管解决方案意味着您可以将资金委托给第三方(如交易所)。此时,您需要登录托管人平台进行加密资产交易。
非托管解决方案正好相反:3354使用加密货币钱包管理资金。加密钱包不像物理钱包那样装载硬币,而是提供允许您访问区块链上的资产的加密密钥。记住:当使用非托管钱包时,一定要备份你的助记符!
如果您想在交易所存放乙醚,请遵循以下步骤:
您需要将ETH存入交易所账户,以方便各种交易活动。将ETH储存在币安上既简单又安全。币安生态系统还允许你通过贷款、职位返利、空投促销和抽奖获得收入。
如果您想从您的exchange帐户中提取ETH,您需要遵循以下步骤:
如果你想在钱包里存放ETH,那么有两种选择:热钱包和冷钱包。
以某种方式连接到互联网的加密货币钱包被称为热门钱包。它通常是一个移动或桌面使用程序,并允许您检查余额,或发送和接收令牌。因为热钱包是联网的,很容易被攻击,但是对于人们的日常使用非常方便。信任钱包是一款支持多种货币的手机钱包。
冷钱包是一种不暴露于互联网的加密钱包。因为没有网络攻击载体,被攻击的概率明显降低。不过冷钱包不如热钱包便携好用。硬件钱包和纸质钱包都是冷钱包。现在已经很少有人用过时且有风险的纸币袋了。
加密钱包分类详情请查看《解读加密钱包类型》。
维塔利克布特林设计了最初的以太坊图案。它由两个旋转求和符号组成(希腊字母中的适局唯掘马)。以太坊最终的logo(基于这个图案)被一个菱形(称为八面体)和四个三角形包围。与其他加密货币类似,以太坊由标准的Unicode符号组成,因此以太坊的价格可以很容易地显示在使用程序和网站中。就像美元是用符号$,以太坊使用的符号是
相关问答:以太币是什么意思?
以太币(ETH)是以太坊(Ethereum)的一种数字代币,以太币和其他数字货币一样,可以在交易平台上进行买卖。但是由于最近币价不稳定,所以现在很少有人炒币了!但是不一定只有炒币才能获得虚拟币ETH,通过挖矿同样可以获得,哈鱼矿工可以快速获得以太坊,那样你就可以快速了解什么是以太坊了!
4. eth2.0还能挖矿吗
可以挖,但是记账方式从PoW转为PoS,质押ETH的方式挖矿,类似于IPFS的挖矿(代币是FIL),根据持有的币量和时间,产出BETH,可以1:1兑换成ETH,然后以太坊会进入通缩时代。产出按地址结算,每个地址质押上限是32个ETH,下限也是这个数目,才能参与挖矿,不排除未来会组建矿池,吸引散户加入,凑够32枚组建一台矿机。因为地址的分散性,有效的降低了主网被算力攻击的风险,一旦发现就没收质押币,成本巨大。通过这种方式,不怎么消耗电力,可谓清洁能源式挖矿,通缩时代也让囤币的矿工收益越来越大。截至2021年6月12日,以太坊2.0内测阶段,质押了545.09万枚ETH。
一、比特币挖矿机,就是用于赚取比特币的电脑,这类电脑一般有专业的挖矿芯片,多采用烧显卡的方式工作,耗电量较大。用户用个人计算机下载软件然后运行特定算法,与远方服务器通讯后可得到相应比特币,是获取比特币的方式之一。
二、2013年流行的数字货币有,比特币、莱特币、泽塔币、便士币(外网)、隐形金条、红币、极点币、烧烤币、质数币。目前全世界发行有上百种数字货币。
三、挖矿实际是性能的竞争、装备的竞争,由非常多张显卡组成的挖矿机,哪怕只是HD6770这种中低端显卡,"组团"之后的运算能力还是能够超越大部分用户的单张显卡的。而且这还不是最可怕的,有些挖矿机是更多这样的显卡阵列组成的,数十乃至过百的显卡一起来,显卡本身也是要钱的,算上硬件价格等各种成本,挖矿存在相当大的支出。
四、支取比特币需要多达数百位的密钥,而多数人会将这一长串的数字记录于电脑上,但经常发生的如硬盘损坏等问题,会让密钥永久丢失,这也导致了比特币的丢失。“粗略估计,丢失的比特币可能达到160多万个。比特币虽然标榜自己“防通货膨胀”,但是它却容易受到持有大量比特币的大庄家的控制,有贬值的风险,涨跌堪称过山车
5. Chainge技术沙龙(0414)-区块链技术的安全隐患
虚拟机设计
零钱整理
慢雾科技介绍
01| The Dao事件
以太坊第一个安全大事件
智能合约的取款
新建一个Bank,存入一部分钱,用Dao框架不停取钱。
取款-判断余额-取款操作框架-转空该账户下的所有钱。
简单的例子就是,你的银行卡有余额100万,你需要买一个10块钱的饮料,但是支付的过程有漏洞,所以你银行卡的所有钱都被转走。
一、外部调用
02| 以太坊黑色情人节
起源:第一转账时间是2.14
ETH节点统计
客户端、客户端版本、OS系统。整个系统的庞杂
蜜罐检测 (部署陷阱能检测出黑客的点来)
net_version
判断是主网还是测试网,只攻击主网
3000+主网节点完全暴露
eth_accounts
获取钱包账号,涉及钱包账号
eth_getBanlance
获取有多少钱,被盗46000+ETH
why?
unlockAccount 函数介绍
该函数将使用密码从本地的keystore 里提取private key 并存储在内存中,函数第三个参数ration 表示解密后private key 在内存中保存默认是300 秒; 如果设置为0,则表的时间,示永久存留在内存,直至Geth/Parity 退出。
详见:
https://github.com/ethereumgethereum/wiki/Management-APIs#personal_unlockaccount
节点存用户的keystore信息(严重危险)
eth_getBlockByNumber
墨子扫描引擎,扫描有问题的节点,慢雾的以太坊安全事件的披露
被盗ETH,市值,被盗钱包数
具体内容可以查看慢雾发布的 以太坊黑色情人节专题
生态相关
ETH:矿池、钱包、web3、smart contract、dapp
BTC:矿池、钱包、Lightning Network
BTC RPC
防御建议
管理数十万用户安全的接近百万的比特币
华人世界唯一被bitcoin.org网站展示的钱包
比特派多种区块链资产(BTC、ETH、Token、分叉)
冷热结合,确保安全
比特派-热钱包
比特护盾-冷钱包/硬件钱包
区块链安全事件
私钥决定了区块链资产的所有权,丢了私钥也就相当于丢了一切。私钥就是一个随机数,这个随机数的概率空间很大(256 位,即2^256)
钱包=生态入口
需要在安全的同时做到尽可能的开放
玩法的开放,技术的开放,通用的技术接口,生态的开放,把自己的资源进行导入。合作伙伴计划:技术咨询、区块链技术支持、开放平台、入口支持、生态支持、海外市场合作。帮助伙伴实现区块链转型或区块链项目孵化,安全、便捷实现真正落地的区块链应用场景。
联系方式 [email protected]
用户风控系统,数百万的数字货币用户。
最大可能保持我们的数字资产
骗子故事:抢数字货币份额,钱没到账,冒充官方,交出助记词
恶意钱包地址库
诈骗钱包、黑客钱包、羊毛党钱包
恶意网站库
钓鱼网站、空投网站、交易所、众筹
风险合约库
重名币、空格币、风险合约
安全事件库
历史安全事件提醒
最新事件提醒
盗币风险监控
安全意识教育
可能出现被盗的情况
游戏即资产,稀缺资源,成为游戏运营者。最后大BOSS死于暴露了自己的密钥。
通过社工(社会工程学)【欺骗的艺术】黑客攻击手法,虚拟景象做出错误判断让自己陷入危机。
人始终是系统中最薄弱的环节,币安背锅的黑客事件。大客户泄露自己的账户,调用API接口,自动交易。虽然没丢币但是黑客在期货市场盈利。
关于安全钱包的帖子(来自小白愤怒控诉,实际没有理解整个机制):
1、我没私钥和交易密码,东西都在你们那我不知道安全在哪里
2、密语算个毛,你告诉我拿着你们的密语能做什么。
汽车和自行车事件,出了问题之后,弱势的一方被原谅。负责的是更大的一方。平台替没有安全意识的用户背锅。
对于大部分用户来说,交易所的安全性比普通用户自己管理的安全性要高,用户的安全意识没有提高,交给交易所帮助、协助你来管理你的钱包提示很多风险操作。
为什么要随机生成256位的密钥,为什么不能用户自己去设置,如果自己设置会处于一个集中的区域,随机值不够,私钥生成时就处于危险的状态。
自己的安全认识不够,所以自己造成的损失,先怼交易所先怼钱包。先想到得是你们的问题和漏洞造成的,不是我的操作失误和密钥泄露造成的。
币派做的是大神和小白的交流之间的翻译,做画漫画,写段子的逗比。
币小宝防骗指南漫画,贡献题材和内容。
6. ETH币是骗局吗ETH币怎么买
ETH币是骗局,是骗子们专门给自以为买了骗子们发行的数字货币就可以赚大钱的韭菜们而发行的,ETH币要在骗子们开的交易所购买!
7. 以太坊技术系列-以太坊数据结构
本篇文章和大家介绍一下以太坊的数据结构,上篇文章我们提到,以太坊为了实现智能合约这一功能,使用了基于账户的模型。我们来看看以太坊中数据结构。
既然是基于账户的模型,我们需要通过账户地址找到账户的状态。就像通过银行卡号可以找到你在银行中的各种信息一样。最简单的想法当然是一个简单的哈希表 key是账户地址 value是账户状态。但这里有个问题解决不了。
轻节点如何校验账户合法性?
上篇我们说过,区块链中有2类节点,全节点和轻节点,轻节点只会存储block header,所以轻节点如何才能校验账号是否合法呢?
这个思路和我们平时用的md5校验一致,我们会对区块内的信息进行hash运算从而得出区块内信息唯一确定的值,区块链所有节点中这个值都是相同的。
在这个过程中我们用到了一种数据结构Merkle Tree(哈希树),我们先看下Merkle Tree(哈希树)的示意图。
上篇文章说到区块链中的链表(哈希链)和我们平时常见链表不同的是将指针从地址改为了hash指,这里也一样,哈希树和二叉树的区别有2个
1.将地址改为了哈希值
2.只有叶子节点存储数据
回到之前的问题轻节点是如何校验1个账户或交易是否是在链上的呢?
整个流程如上图所示
1.轻节点需要判断1个账号是否合法
2.轻节点由于只存储block header,所以拿到1个账号的时候会向全节点发出请求
3.全节点存储了所有账户状态,将账户路径中的需要计算用到的hash值返回给轻节点
4.轻节点本地进行计算根hash值,如果计算结果和自己存储一致则账户合法,不一致则不合法。
那以太坊中的账户信息的数据结构就是这样吗?
直接用这样的数据结构来存储账户信息会有2个问题
查找困难
生成hash值不确定
第1个问题应该比较容易发现,在这个树中寻找1个账号需要的复杂度是O(n),因为没有任何顺序。
第2个问题其实也是因为无序导致的,无序的组合每个节点针对同一批账户生成的hash值不一致,这就导致无法达成共识。
既然2个问题都和顺序有关,那我们类似二叉排序树一样,使用哈希排序树是不是就可以解决问题了呢?
使用排序树后会带来另外1个问题
插入困难
因为要维持树是有序的,很可能带来树结构的很大变动。
以太坊中使用了另外一种数据结构字典树。和哈希树不同,字典树应该是很多地方都有使用。我们简单来看下字典树的结构。
字典树能够较好地解决哈希树的2个缺点1.查找困难 2.生成的hash值不确定以及排序二叉树的1个缺点 插入困难。
但字典树我们可以看到可能树的深度可能由于部分元素导致整棵树深度非常深。
这时我们可以进一步优化,将相同路径进行压缩。这就是压缩字典树。
将哈希树和压缩字典树结合,就可以得到以太坊存储账户的最终数据结构-MPT。
将压缩字典树里面的指针从地址改为指针,并且将数据存储在叶子节点中即可。
介绍完状态树的数据结构,我们接下来讨论1个问题,区块中存储的账户状态是什么样的范围。有2种选择。
只保存当时区块中产生交易的账户状态。
保存全局所有的账户。
我们可以看下这2种方式,无非就是空间和时间的平衡,只保存当前区块产生的交易意味着是做懒加载(需要的时候才去寻找账户),在区块链中这个代价是非常大的,因为寻找的账户之前从未交易过,这样会遍历整个区块链。另外一种保存全局的账户方式虽然看起来空间消耗较大,但查找快捷,而且空间的问题我们可以通过其他方式优化。所以最终以太坊选择了第2种每个区块都报错全局所有账户的方式。
我们来看下以太坊中是如何保存状态树的。
可以看到以太坊中虽然每个区块都保存了全部账户,但是会将未发生变化的账户状态指向前1个节点,本身只存储发生变化的状态,这样可以较大程度优化空间占用。
介绍完以太坊中比较复杂的状态树后,我们继续来看看以太坊中的另外两棵树,交易树和收据树。
首先介绍一下,为什么需要交易树&收据树。
1.交易树
虽然以太坊是基于账户的模型,但是就像银行不仅会存储银行卡的余额,还会存储卡中的每笔钱怎么来的以及怎么花的。交易树中就存储着当前区块中的包含的所有交易。
2.收据树
由于智能合约的引入增加了不少复杂性,所以以太坊用收据树存储着一些交易操作的额外信息。比如交易过程中执行日志就包含在收据树中方便查询。收据树和交易树是一一对应的。每发生一次交易就会有一次收据。
和状态树不同交易树和收据树只维护当前区块内发生的交易,因为当时区块发生交易时不需要再去查找另外1个交易,也就之前需要可能遍历整个区块链的查找操作了。
由于以太坊中的出块速度较快,我们进行一些查询一些符合条件交易的时候会面临大量数据遍历困难的问题。收据树中引入了布隆过滤器可以帮助我们有效缓解这一困难。
布隆过滤器将大集合中每个元素进行hash运算映射到1个较小的集合,这时再来1个元素要判断是否在大集合的时候,不需要遍历整个大集合,而是去进行hash运算去小集合中寻找是否存在,如果不存在,肯定不在大集合中,如果存在则不能说明任何问题。
如上图所示,布隆过滤器只能证明某1个元素不在集合中,不能证明1个元素在结合中。
以太坊中如果我们要在较多区块中寻找某1个交易,则可以利用布隆过滤器,过滤掉肯定不存在目标交易的区块,然后进入收据树内继续利用布隆过滤器筛选,剩下的才是可能的目标交易的交易,进行一一比对即可。
我们介绍了以太坊的核心数据结构,状态树&交易树&收据树,他们都是使用相同的数据结构-哈希压缩字典树。但状态树是维护1颗全局账户树,交易树和收据树则是维护本区块内的交易或收据。
介绍完数据结构后,后面我们会用几篇文章来介绍以太坊中的一些核心算法,比如共识机制,挖矿算法等。
8. ETH 查询某个钱包的所有代币以及地址
思路:
1、获取钱包W的所有交易记录
2、把from、to记录到数组A中
3、根据ABI规则,input去掉前面8字符大小的方法名,剩下的依次按64字符进行分割,得到参数列表。因为地址都是居右的,所以取出居右的参数后,对比ETH地址长度,一致则存到数组A中待用
4、遍历数组A,调用ERC20的标准合约方法symbol、decimals,如果都存在则表示该元素为代币,将塔存到数组B待用
5、遍历数组B,调用ERC20合约方法balanceOf获取代币余额,存到数组C中
6、此时,我们就成功获取到钱包W的所有代币B,及其余额C
2022年02月15日
9. 我能自己来运行 Eth 2.0 的验证者吗
可以!
你在运行自己的验证者节点时,首先要意识到的是,你这样做是有助于网络安全性的,而且你无需过度担心正常运行时间。
假设网络总体上是健康的(始终有超过 2/3 的节点在线,并且一直在终局化新的区块),在线时间超过 50% 的验证者将看到自己的权益会不断增加。
引用以太坊基金会的 ETH Staking 指南系列文章中的一句话:
这就减轻了验证者在客户端备份和网络延迟上的负担,因为离线的惩罚并不那么严重。
自己运行验证者节点并不像你想象中那么可怕或昂贵。一旦ETH 2.0上线,你就可以在一个旧手机或树莓派(100 美元)上运行验证者节点。
我们专门为开发者撰写了关于如何使用 Nimbus 在安卓系统上运行验证者节点的指南(分别是这篇和这篇)。在主网上线前,我们一直在尽可能简化这一流程。尤其值得一提的是,主网指南将面向那些没有编程经历的用户,而且会尽可能实现 “安装 + 质押 ETH = 正常运行”。
你可以帮助以太坊增强抗攻击性与其让同一个实体控制 100 个节点,不如让一个实体控制一个节点。——Barnabe Monnot
从长远角度来看,以太坊的价值越高,抗攻击性越强,其共识层的去中心化程度就越高。
中本聪最初的愿景是 “一 CPU 一票制”,但是如今的 PoW 系统已经偏离了这一愿景。就目前而言,绝大部分挖矿资源都集中在少数矿池手中。个体矿工都为了缩小自己收入的波动性而加入矿池。
我们之所以选择从 PoW 模式转向 PoS 模式,也是为了解决这一问题。
如果有越来越多人选择自己运行验证者节点,我们就可以将这一愿景变为现实,增强以太坊的抗攻击性,使之在无需审查的情况下不断发展。