服务可以以类似的方式使用以太坊智能合约事件,以太坊网络充当一种消息队列。非链服务可以向节点注册一个事件过滤器,然后每次在以太坊网络中发出此事件时都会通知该过滤器。然后,您可以使用这些事件通知作为进一步的链外处理的触发器,例如更新智能合约状态的基于NoSQL的缓存。
以太坊作为“事件总线”
廉价的数据存储用于链外消费
如上所述,在事件中存储数据而不是在EVM合同存储中存储数据要便宜得多。
为了进行比较,稍微深入了解一下细节,将32字节的数据保存到合同存储需要消耗20000气体,而发送一个事件需要消耗375加上每个索引参数的375气体,每个字节的数据需要额外的8气体。
由于这些成本节约,在事件中存储从不由链上智能合约函数soley读取的数据是一种常见的模式,而不是在合约存储中。
一个可能是这种情况的场景示例是一个公证服务,其中IPF哈希被提交到以太坊区块链以证明创建日期。在发出包含文档的IPFS哈希的事件后,如果存在争议,可以通过查询合同事件(而不是合同状态)来验证链外公证的时间戳。
定义和发出事件
您的以太坊智能合约中的定义、发送和事件都是一段代码:
定义
event Notarized(address indexed notary, string documentHash)
在这个例子中,我们定义了一个名为Notarized的事件,带有索引地址参数,notary和一个非索引字符串参数documentHash。
发送
function notarizeDocument(string _documentHash) public {
emit Notarized(msg.sender, _do