理解以太坊上的事件日志

译文出自:登链翻译计划

译者:Tiny熊

序言:先阅读一下以太坊虚拟机,可能会有所帮助,在本文中,我会跳过基础知识直接研究。

在传统编程中,应用程序经常使用日志来捕获和描述特定时刻的情况。这些日志通常用于调试应用程序,检测特定事件或将日志中发生的事情通知查看者。事实证明,在编写智能合约或与智能合约进行交互时,日志也非常有用!那么以太坊是如何做的呢?

以太坊上的日志

EVM当前有5个操作码用于触发事件日志:LOG0,LOG1_,LOG2,_LOG3和LOG4。

这些操作码可用于创建“日志记录”。日志记录就是用于描述智能合约中的事件,例如代币转移、所有权变更等。

以太坊黄皮书-拜占庭版本69351d5(2018-12-10)

每个日志记录都包含“主题(topics)”和“数据”。主题是32字节(256位)的“词”,用于描述事件中发生的事情。不同的操作码(LOG0…LOG4)来描述需要包含在日志记录中的主题数。例如,“LOG1”包括“一个主题”,而“LOG4”包括“四个主题”。因此,单个日志记录中可以包含的最大主题数是四个。

Poly Network生态核心贡献者:建立统一的跨链安全模型有助于我们系统化理解互操作风险:4月15日消息,在2023香港Web3嘉年华跨链专场中,Poly Network生态核心贡献者Luke Liu认为,建立统一的跨链安全模型有助于我们系统化理解互操作风险。跨链的目标是标准化通信过程,保证一条链上的请求在另一条链上被正确、顺利地执行。各条链是不同的,但我们尽量建立起统一的风险模型,包括数据请求、通信、验证三个环节。经由数学(模型)抽象,区块链系统中的多链互操作包含应用、通信、共识等不同层的协同,这一套组合交互系统既依赖各组件的安全性,也考验各组件之间交互的安全性。建立起这样的(安全)框架可以帮助我们更系统性地理解互操作风险,而非根据个例归纳。[2023/4/15 14:05:26]

以太坊日志记录中的主题

日志记录的第一部分由一组主题组成。这些主题用于描述事件。第一个主题通常为事件名称及其参数类型(uint256,string等)签名(keccak256哈希)。一个例外是触发“匿名事件”没有事件签名。由于主题只能容纳32个字节的数据,因此无法将数组或字符串等的内容用作主题。而是应将其作为数据包括在日志记录中,而不是作为主题。如果要尝试包含大于32个字节的主题,则该主题需要被hash计算。因此,仅当你知道原始输入时,才可以知道此哈希表示的内容。

V神:NFT需要经历多个寒冬才能理解它的长期价值:金色现场报道,10月26日消息,由万向区块链实验室主办的第七届区块链全球峰会在上海举行,以太坊创始人、万向区块链实验室首席科学家Vitalik Buterin分享称,DeFi和NFT发展的都非常不错,但他认为当前存在一个现象,人们很努力以至于使得DeFi很复杂,比如收益耕作使得智能合约出现合约风险,风险可能会大于收益。他认为最有用协议还是最简单的那种。他还认为,NFT非常具有价值,他给了创作者一个全新的商业模式,但他提醒公众,人们不应该假设说NFT按当前的形式在经济上是具有可持续性的,NFT需要经历多个寒冬。“我们看到这个领域的项目在6个月到1年里表现很不错,但1-2年时间里却会变得无名,我觉的必须要耐心等待,必须理解长期可持续的NFT会是怎么样的。[2021/10/26 20:58:19]

总之,主题应该仅用于需要搜索查询(例如:地址)的数据。可以将主题视为事件的索引键,它们都映射到相同的值,接下来将讨论。

以太坊日志记录中的数据

日志记录的第二部分包含额外的数据。主题和数据在一起组成日志记录,主题和数据每自有其优点和缺点。例如,主题是可搜索的,但数据却不能。而数据比主题“便宜得多”。此外,尽管主题最多有4个,但数据却没有限制,这意味着它可以包括大量或复杂数据,例如数组或字符串。因此,事件数据(如果有)可以视为_值_。

动态 | 美国国土安全部奖励区块链创业公司20万美元,用于开发证书管理解决方案:据The Block消息,美国国土安全部(DHS)向区块链创业公司Digital Bazaar奖励近20万美元,用于建立一个证书管理解决方案。DHS表示,目前颁发、验证和验证大量许可证和证书的流程通常是纸质的,不利于数据交换,而且容易丢失、伪造和伪造。它补充说,使用区块链技术将这些过程数字化有助于增强安全性、确保互操作性和防止伪造和假冒。因此,Digital Bazaar将致力于一个名为“可互操作的企业身份和凭据生命周期管理”的项目,以帮助DHS改进其流程。[2019/11/15]

让我们看一些示例,看看主题,数据和日志记录是如何使用的。

触发事件

以下实现了ERC20的代币合约,使用了Transfer事件:

由于这不是匿名事件,因此第一个主题将包括事件签名:

现在,让我们看一下此Solidity事件的参数(from_,to,_value):

由于前两个参数声明为indexed,因此被视为主题。最后一个参数没有indexed,它将作为数据(而不是单独的主题)。这意味着我们可以进行这样的搜索:查找所有从地址0x0000...到地址0x0000…的转账日志,或者是“所有转账到地址0x0000…的日志”,但没法搜索“转账金额为x的转账。我们知道了此事件将具有3个主题,这意味着此日志记录操作将使用LOG3操作码。

声音 | Intergalaxy首席执行官:Libra处于初始阶段 对其的批评及支持均可理解:据福布斯报道,Intergalaxy首席执行官Francis Silva表示:我们注意到Libra最近的新闻有两种主要的反应。一种来自感到威胁或担忧的批评者,另一种来自认为该项目有潜力创造新的全球金融解决方案的支持者。这两种观点都是完全可以理解的,因为Libra仍处于项目的初始阶段。[2019/7/24]

现在,我们只需要了解如何包含数据(即最后的参数)即可。LOG3需要5个参数:

LOG3(memoryStart,memoryLength,topic1,topic2,topic3)

通过以下方式从内存中读取事件数据:

memory

幸运的是,像Solidity,Vyper或Bamboo这样的高级智能合约程序设计语言将为我们处理将事件数据写入内存的过程,我们可以在触发日志时直接将数据作为参数传递。

检索事件日志

通过使用web3JavaScript库,可用于与本地或远程以太坊节点进行交互,我们能够订阅新的事件日志:

声音 | 安永:超过三分之二的亚太公司缺乏对区块链解决方案的理解:据businesstimes报道,安永会计师事务所(Ernst&Young,EY)在一个实时区块链直播中调查发现,在区块链解决方案方面,超过三分之二或68%的亚太公司对其应用缺乏了解和教育。安永周二表示,缺乏理解和教育是董事会和高管在采用区块链解决方案时面临的最大障碍。此外,大约三分之二或66%的受访者认为,在将区块链应用于组织之前,他们需要更好地了解区块链的可能性,风险和好处。此次调查共有576名亚太地区参与者,其中13.7%来自新加坡。[2019/7/16]

每当发生新的SAI代币转账时,此代码都会通知我们,接收到事件通知,这对很多应用程序都很有用。例如,一旦你在以太坊地址上收到代币,钱包界面就可以提醒你。

日志的gas成本

根据黄皮书、日志的基础成本是375gas。另外每个的主题需要额外支付375gas的费用。最后,每个字节的数据需要8个gas。

这实际上是很便宜!可以计算一下一个ERC-20代币转移事件的成本。首先,基本成本为375gas。其次,“转移”事件包含3个主题,这是另外的375_3=1125gas。最后,我们为所包含的每个数据字节添加8gas。由于数据仅包含ERC-20转账的数量,最大为32字节,因此用于记录日志数据所需的最大gas量为8_32=256gas。这总计要花费1756gas的总gas成本。作为对比参考,标准的以太币(非代币)转账要花费21000gas,是事件成本的十倍以上了!

如果我们假设gas价格为1gwei,那么操作的总成本将为1756gwei,相当于0.000001756ETH。如果以太坊的当前价格在200美元左右,那么总计为$0.0003512。请记住,这是在全球范围内将数据永久存储的费用。

声明:这只是日志记录操作本身的成本。任何以太坊交易至少需要21000gas,并且交易的输入数据每字节最多花费16gas。通常,要转账和日志记录ERC-20代币,费用在40,000–60,000gas。

结论

日志是一种以少量价格将少量数据存储在以太坊区块链上的优雅方法。具体来说,事件日志有助于让其他人知道发生了什么事情,而无需他们单独查询合约。

参考文献

Wood,G.(2014)。以太坊:一个安全的去中心化通用交易账本

以太坊基金会Solidity文档

Web3文档

本翻译由CellNetwork赞助支持。

来源:https://medium.com/mycrypto/understanding-event-logs-on-the-ethereum-blockchain-f4ae7ba50378

参考资料

登链翻译计划:https://github.com/lbc-team/Pioneer

Tiny熊:https://learnblockchain.cn/people/15

以太坊虚拟机:https://medium.com/mycrypto/the-ethereum-virtual-machine-how-does-it-work-9abac2b7c9e

以太坊黄皮书:https://ethereum.github.io/yellowpaper/paper.pdf

keccak256:https://en.wikipedia.org/wiki/SHA-3

Solidity:https://learnblockchain.cn/docs/solidity/

Vyper:https://github.com/ethereum/vyper

Bamboo:https://github.com/cornellblockchain/bamboo

web3:https://learnblockchain.cn/docs/web3.js/

Wood,G.(2014)。以太坊:一个安全的去中心化通用交易账本:https://ethereum.github.io/yellowpaper/paper.pdf

以太坊基金会Solidity文档:https://solidity.readthedocs.io/en/latest/

Web3文档:https://learnblockchain.cn/docs/web3.js/

CellNetwork:https://www.cellnetwork.io/?utm_souce=learnblockchain

本文来源于非小号媒体平台:

登链社区

现已在非小号资讯平台发布105篇作品,

非小号开放平台欢迎币圈作者入驻

入驻指南:

/apply_guide/

本文网址:

/news/9558537.html

免责声明:

1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险

2.本文版权归属原作所有,仅代表作者本人观点,不代表非小号的观点或立场

上一篇:

币安为何推出第三条链?这对BNB意味着什么?

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

银河链

[0:15ms0-0:879ms