EOS:Ultrain超脑链发现并协助修复EOS致命安全漏洞并获官方致谢

据悉,Ultrain技术团队核心成员近期在阅读EOSchainbase开源代码时,发现其底层实现存在可导致EOS全网宕机隐患的致命安全漏洞,并立即将问题详细描述及修复办法提交至EOS团队。近日,EOS团队已正式将修复提交EOS代码主分支,并对于Ultrain@raymondnuaa表示多次致谢!

公链EOS采用chainbase内存数据库存储世界状态,包括链上所有账号详情、部署的所有智能合约以及所有历史交易形成的状态修改等内容。chainbase的安全性与稳定性是保证公链EOS稳定运行的重中之重。

Morning Consult调查:超过五分之一的美国成年人考虑购买比特币:金色财经报道,根据决策情报公司 Morning Consult 最近发布的一项调查,截至上周,超过五分之一的美国成年人正在考虑购买市值最大的加密货币比特币。根据调查,最近的加密崩盘并没有削弱比特币所有者的热情,他们中的大多数人愿意逢低买入。千禧一代仍然是对加密货币最友好的人群,其中近三分之一的人愿意购买比特币。此外,男性以及年收入超过 10 万美元的受访者也比普通美国成年人更愿意投资比特币。[2022/2/2 9:27:15]

EOS该安全漏洞由chainbase对数据库回滚操作的错误处理顺序引发。chainbase内存数据库底层有removed、created、modified三个stack来存储区块内交易对数据库对象所进行的删除、创建、修改操作,如果该区块未能成功添加到区块链主链,则需要对该区块内所有交易对内存数据库做的所有修改进行回滚。EOS对三个stack的原有回滚处理顺序为:modified,created,removed,在该处理顺序下,如果将数据库某个已有对象A的键值修改,并创建一个新的对象B采用前述对象A的原有键值,那么在进行回滚时,会先尝试将对象A修改过的数值恢复,此时会产生键值冲突,导致底层库进入死循环状态。一旦进入该状态,EOS节点则无法正常继续生产区块。若恶意攻击者构造触发该状态的交易广播至全网执行,则EOS全网存在宕机隐患。

yearn.finance发起添加yRenBTC Delegated Vault的新提案:yearn.finance社区成员发起添加yRenBTC Delegated Vault的新提案。具体来说,即在Vault产品中创建一个RenVM Bridge存款形式,类似于Curvefi的做法。用户存入BTC(或RenBTC),我们给用户yRenBTC,把他们的BTC转化为RenBTC,创建一个CDP,通过任何方法使用DAI,利用管理抵押品和使用我们的Vault生成收益,用于购买市场上的RenBTC,然后以RenBTC向存款人交付回报。[2020/8/24]

发现问题后,EOS开发团队按@raymondnuaa建议将stack处理顺序修改为created,modified,removed,可正常处理前述场景。此外,@raymondnuaa在问题描述中还详细描述了另一个更加复杂的两个对象键值交换的场景,并指出仅靠调整三个stack的处理顺序无法解决问题。EOS在此次修改中也增加了大量注释,明确了chainbase内对象的使用需求限制,指出chainbase的特定字段不能在modifier中进行修改,并对deferred_transaction的modify处理做了相应修改。

动态 | Nano将发布新节点更新Boulton:据bitcoinexchangeguide报道,Ledger背后的公司Nano宣布其即将推出的节点更新Boulton将为客户提供一系列新功能和技术改进。大多数分析师都期待引入“懒惰引导”模块,这将允许Nano的本机操作系统大幅提高其分类帐的更新效率。不仅如此,“延迟引导”还为用户提供了一种高效的方法,可以批量添加块到分类账(每个节点的整体CPU和带宽使用量可以大大减少)。[2018/11/13]

公链是促进区块链行业繁荣发展的一个重要角色,相信有如Ultrain这样致力于提升基础设施安全的公链存在,整个行业将会更加健康有序发展。

详情链接:

https://github.com/EOSIO/eos/pull/7266

https://github.com/EOSIO/chainbase/pull/44

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

地球链

[0:15ms0-0:585ms