内存池——交易的驿站

01交易是区块链的基石

交易是区块链的基石,我们每天都会接触到各式交易,不论你是操作DeFi,还是转账购买NFT,或者只是单纯的从交易所提现/充值,交易都是上述操作的基础。

不过,鲜有人知晓交易的中转站——内存池的重要性,由于大量教材为大家提供了“区块链是一个不需要中介的交易账本”这个概念,如果不深入了解区块链的技术细节往往会忽略内存池,并导致在一些特殊时刻出现不必要的损失。

比特币、以太坊、WisdomChain都有内存池设计,几乎所有的区块链项目都离不开内存池,那么究竟什么是内存池?内存池又在交易过程中扮演了什么角色呢?

02内存池是什么?

要了解内存池的概念,首先我们需要回顾交易的状态。

波卡回顾上个月客户端事故 系内存不足导致:6月7日消息,Polkadot官方发文回顾,5月24日要求波卡验证节点将客户端降级至0.8.30版本事故,系内存不足导致。Polkadot表示,在试图构建区块5202216时因内存不足(OOM)错误而失败。该区块包含验证人选举的链上解决方案,该解决方案通常是在链下计算的,只有在没有提交链下解决方案的情况下才会在链上进行。由于提名者的数量众多,选举溢出了Wasm环境中分配的内存。为解决这个问题,当时验证者被要求暂时将他们的节点软件降级到至0.8.30版本并且使用「--execution=native」命令。该本地版本不受Wasm内存分配器的限制,网络在70分钟停机后恢复。之后在5203204区块,几个节点因「存储根不匹配」错误而失败,这是由于构建本地运行时和链上Wasm运行时的编译器版本不同造成的。解决方案是用一个具有正确编译器版本的Wasm运行时来覆盖链上Wasm运行时。Polkadotv0.9.3版本上线后修复了该类问题,Polkadot表示未来可能会支持4GB的Wasm分配内存。现在选举必须在链下进行,并且禁用链上选举。在分配器被改进之前,链下工作者将使用比链上Wasm运行时更高的内存限制确保链下选举不会耗尽内存并能成功提交。另外,Polkadot将确保本地和Wasm构建中使用相同的编译器版本。[2021/6/7 23:18:48]

相信大家在操作以太坊,尤其是近期拥堵的以太坊时,如果设置了较低的手续费,那么交易将会被等待一段时间才会被矿工打包。

以太坊2.0客户端Teku发布v21.5.0,新数据库使用LevelDB来减少内存使用并提高可靠性:官方消息,以太坊2.0客户端Teku发布v21.5.0,关键更改包括:新数据库现在使用LevelDB来减少内存使用并提高可靠性,现有数据库不受影响;支持eth1端点的自动故障转移。[2021/5/12 21:53:08]

等待的这段时间交易将会储存在收到这笔交易的矿工节点中,而矿工节点则会将这些等待被它打包的交易存放在“内存池”中。

放在内存池中的交易,矿工一般会按照手续费价格的多少来进行排序,优先打包价格较高的交易,至于手续费比较少的交易自然就必须排队了。

不过由于矿工每时每刻都会接收到其他节点发来的新交易,这些交易也会不断的更新到内存池中,因此矿工也会在一定时间后重新排列交易池中的顺序——换句话说,如果你的手续费太低,那么交易有可能一辈子都不会被打包。

JustLend 上线24小时内存款规模已超8200万美元:据官方最新消息,波场TRON网络上的首个官方借贷项目JustLend 上线24小时内存款规模已超8200万美元,据悉,JustLend已于昨日正式上线。截至目前,JustLend存款规模Top前三的币种分别为TRX、USDT、BTC。据悉,JustLend致力于打造完美的去中心化借贷协议,将成为波场上的首个官方的“去中心化算法银行“。JustLend是波场TRON网络首个官方借贷平台,用于建立基于波场TRON资产的供求变化,以算法计算得出利率的资金池。协议中存在两种角色,包括资产的存款方和借款人,并且资产的存款方和借款人可以直接与协议进行交互,从而赚取或支付浮动利率。[2020/12/8 14:33:48]

以太坊和比特币虽然采用了完全不同的结构,但他们的交易内存池设计都是大同小异的,或者说,所有的区块链项目在内存池上的设计都大同小异,我们以WisdomChain的内存池作为例子:

原力区协助官方解决Filecoin内存问题:据官方消息,原力区工程师分析并提出Filecoin内存问题和系统问题的解决方案,目前原力区协助官方Testnet/3--Touch Issue已在解决,同时此问题引发Filecoin社区史上最长技术主题讨论。Filecoin二阶段测试网有望下周上线devent。[2020/4/17]

上述各个参数定义了WisdomChain中内存池的各个特点,我们挑选其中最重要的几点进行解释:

1Pending

pending代表着尚未被矿工打包的交易,这些交易已经经过了初次校验并等待被矿工打包

2Queued

queued代表着初步被验证过的交易,但这些交易的优先级比pending低,处于”等待进入pending“队列的状态。需要注意的是pending和queued队列也会按照Nonce随机数来进行排序。

3过期时间

过期时间。交易如果超过了一段时间将会从内存池中清除,用户需要重新向网络广播交易才能让交易被放入到矿工的内存池中

4手续费

手续费,顾名思义,避免大量无意义的交易填塞网络导致拥堵。

5最大事务数

最大事务数。确保矿工的内存池不会储存过多交易,导致节点宕机。

不论比特币、以太坊,内存池的设计都离不开”交易队列“,”手续费门槛“,”内存池上限“三大概念,WisdomChain中也是如此。

03为什么需要内存池?

试想一下,如果没有内存池,区块链会发生什么?

虽然作为点对点交易的媒介,区块链看起来是一个用户同另一个用户直接交易,就像线下一手交钱一手交货一样,加入交易池作为中介媒介似乎是徒增摩擦成本。但实际上,内存池的存在不仅没有对网络造成负担,甚至还是网络减负的重要手段。

如果没有内存池,首先区块链就丧失了对粉尘攻击的抵抗性。所谓区块链上的粉尘攻击,指的是大量毫无意义的交易填充了整个区块网络,而交易验证是需要花费时间和算力的,如果用户和矿工节点被大量的粉尘交易所填塞,那么他们将无法正常的验证并打包本应当正常的交易。

甚至如果矿工节点不设上限地接收粉尘交易,交易将会直接填满矿工节点的内存导致宕机。内存池的存在,通过最大事务数和手续费门槛,确保无价值的粉尘攻击不会让网络陷入拥堵状态。

交易额低数量大

其次,缺乏内存池,网络激励机制将会受到挑战。内存池设置了按照随机数手续费进行排列的交易队列,为的是让矿工尽可能以网络、用户还有矿工个人所期望的方式打包交易——即优先高手续费的交易。

如果缺乏内存池,虽然从利己角度矿工依然会选择较高手续费的交易进行打包,但恶意矿工可以通过以低手续费门槛吸引大量的交易并孤立其他矿工,如果交易过多的聚集在某个矿工控制的节点下,发动双花攻击的难度也会有所下降。

另一方面,如果矿工对交易不按照随机数进行排序,那么事务/合约的执行也会存在问题。如果一个矿工节点收到了来自一个用户的多笔交易,在内存池的辅助下交易将会按照随机数大小进行排列,本质上也符合交易的”理想发起时间“。

缺乏内存池,如果在网络存在延迟的环境下,用户发起的交易并不会按照实际发送时间广播到矿工手中,矿工如果单纯按照接收时间来执行某一用户的多笔交易,那么对于事务/合约这种严格限定交易先后顺序的设计,错序交易会让用户无法正常的调用合约。

04?内存是交易的驿站

内存池是交易的驿站,或者说港口。所有的交易都需要在内存池进行校验、打包、排序,之后才会经由矿工发送到区块链网络中。如果忽视内存池设计,或者忽视内存池的存在,在市场剧烈波动或者网络环境不稳定的情况下,是会发生类似3.12MakerDAO0价格ETH拍卖乌龙事件的。

本文来自WisdomChain公链社区

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

银河链

火必下载COINW即将全球首发六域链(SDA)公告

六域链是全球首个融合物联网“六域模型”国际、国家标准和分布式区块链参考架构标准的去中心化公有区块链生态体系,充分考虑物联网技术特点和商业生态建设需求.

[0:15ms0-1:733ms