以太坊交易事务的打包规则

2024-09-03 08:18

本文主要是介绍以太坊交易事务的打包规则,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

以太坊交易的本质

首先,大家应该都知道以太坊交易的本质:我给你 10 个以太币不是我真的把什么东西给了你,而是我向以太坊网络提出了更改余额状态的请求,让各个节点上纪录的你与我的 Ether Balance 进行更新。

以太坊交易之状态更新示意图

以太坊交易之状态更新示意图

然而,送出交易在技术上并不困难,区块链的重点是在于打包交易并出块的过程。如何验证、确认交易是否有效,让这笔交易顺利发生,并让各个节点即时更新以拥有相同的帐本,这样打包交易并出块的机制即「挖矿」。

以太坊交易送出至出块的流程

以太坊交易送出至出块流程 

以太坊交易送出至出块流程 

通过上图我们可以看出

在以太坊上一笔交易送出后经历的流程:

1.发送交易

2.私钥签名

3.交易发送至节点

4.节点间广播新接收交易

5.矿工打包交易并出块

交易送出之后,会被丢进一个「交易池」里,等待被矿工打包。

矿工从「交易池」中捞出未出块的交易来进行打包与出块。

因为每个区块有大小限制,比特币一个区块是1MB 的容量限制;以太坊的区块则是以 Gas 来计算,有 800 M Gas 的限制。若以一笔基础交易 21,000 Gas 来计算,一个以太坊区块可以容纳 380 笔交易。因此当「交易池」里的交易量大时,会有许多交易没办法即时被打包而滞留在池子中等待。

如何挑选要捞出哪些交易?

矿工节点可以自行设置参数,不过大多数矿工都是按造手续费的多寡排序,手续费高的会优先被打包出块;手续费低的则可能要等到天荒地老。

以太坊手续费计算公式:

以太坊交易手续费公式:Tx Fee(手续费)= Gas Used(燃料用量) * Gas Price(单位燃料价格)

由于 Gas Used 是由系统决定的,我们在发送交易时决定手续费多寡的决定性变因就是 Gas Price 了。下方我们以 Metamask 接口来做介绍:

Metamask发送交易的页面流程图

Metamask发送交易的页面流程图

在上图左方我们可以看到系统缺省有三个速度可以供选择,不过要更近一步设定,可以点「进阶选项」,便会进到上图右方的划面。

我们可以自行设定 Gas Price 及 调整交易的 Gas Limit。WEI 是以太坊上最小的单位(10^-18 Ether);GWEI 则是 1G 的 WEI(10^-9 Ether)。
图中的 Gas Price 设定为 10 GWEI;Gas Limit 为 21,000。因此:

10 GWEI(单位燃料价格)* 21,000(燃料用量)= 0.00021 Ether(手续费)

Gas Limit

若是要操作智慧合约等较繁复的功能,不太确定实际的 Gas Used,也可以把 Gas Limit 调高一些,被打包时只会收取实际 Gas Used 作为手续费,多给的 Gas 会退返回来。

不过由于以太坊区块有 800M 的大小限制,若把 Gas Limit 设太高,也可能产生塞不进区块中而滞留在「交易池」里的情况。

GWEI

至于要设多少 GWEI,我们可以到 ETH gas station上查看即时的「交易池」状况:

ETH GAS STATION 上的 Gas Price 建议

ETH GAS STATION 上的 Gas Price 建议

可以看到如果希望交易能尽快被确认,GWEI 可能要设到 20 以上,大约在 2 分钟内可以被确认完成(不过通常设到 FAST,应该 15~30 秒就会被确认了)。截图当下其实是偏拥堵的情形,通常 10 GWEI 左右就可以达到 FAST(<2 mins),现在却要 20 GWEI。

这边显示的 Gas Price 建议,其实就是「交易池」里的状况:池里有多少笔 pending 的交易、这些池里的交易给的手续费是多少。根据这些资讯依据来呈现设的 Gas Price 估计要多少个区块(时间)后才会被打包上链。

然而,许多人常遇到关于交易的问题:

我的交易怎么一直送不出去怎么办?

也许是 Gas Price 设太低,或是突然有大量交易湧入等各样的情况。这时其实有补救的方法:

加速交易

当交易由 Metamask 送出后,可以看到下方会有个「加速」的按钮,点进去后便可以再次设定 Gas Price,设定并重新送出交易后,就可以在底下的活动纪录看到手续费被提高了。

取消交易

除了能加速交易,其实也可以取消交易。方法便是点击等待处理的交易,展开后可以看到「取消」的按钮,点击并确认后 Metamask 会向节点发送取消交易的请求,并在确认取消后收取手续费。

若发现取消交易的请求 pending 有点久,其实在下方可以看到有「加速取消」的按钮,可以再进行进一步设定。

那麽,以上这些过程其实是发生了什么事,技术上如何做到的呢?

答案跟我们在 第一节谈到的 nonce 有关,做法是:

再发送一个同样 nonce 的交易

由于以太坊 nonce 的设计,会追踪每个地址所有交易的「序次」,也就是说每个 nonce 只会有一笔交易。

加速交易

因此加速交易便是我再发送一笔同个 nonce、同样内容的交易。因为提高了交易手续费,所以当同样 nonce 的两个交易都位于「交易池」中,后发的手续费较高的交易原则上会被优先打包出块。

因为每个 nonce 只能有一笔交易,先发的那笔手续费较低的交易永远不会被打包,于是便会被系统给丢弃,因而交易失败。

取消交易

取消交易其实也是类似的逻辑,做法是:

我再发送一笔给自己 0 Ether 的同 nonce 交易。由于这笔交易手续费较高,会优先被打包出块,让原交易被系统丢弃而交易失败,如此来达到取消交易的目的。

结论

1.交易送出后会被丢到一个交易池中等待被矿工打包,决定先后顺序的主要因子为单位 Gas Price(GWEI)给的多寡。

2.发送交易时可以到 ETH gas station参考即时的交易池状况再来决定要设多少 GWEI 以能在预期的时间内被打包上链。

3.若发现交易持续滞留在交易池中等待被处理,可以加速交易或取消交易。

综上所述,大家应该都对以太坊交易的背后逻辑与打包规则有更深一层的认识了。

​区块链技术知识:以太坊交易的打包规则-有一亿

这篇关于以太坊交易事务的打包规则的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1132500

相关文章

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

Spring 中的切面与事务结合使用完整示例

《Spring中的切面与事务结合使用完整示例》本文给大家介绍Spring中的切面与事务结合使用完整示例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录 一、前置知识:Spring AOP 与 事务的关系 事务本质上就是一个“切面”二、核心组件三、完

idea Maven Springboot多模块项目打包时90%的问题及解决方案

《ideaMavenSpringboot多模块项目打包时90%的问题及解决方案》:本文主要介绍ideaMavenSpringboot多模块项目打包时90%的问题及解决方案,具有很好的参考价值,... 目录1. 前言2. 问题3. 解决办法4. jar 包冲突总结1. 前言之所以写这篇文章是因为在使用Mav

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

Redis分片集群、数据读写规则问题小结

《Redis分片集群、数据读写规则问题小结》本文介绍了Redis分片集群的原理,通过数据分片和哈希槽机制解决单机内存限制与写瓶颈问题,实现分布式存储和高并发处理,但存在通信开销大、维护复杂及对事务支持... 目录一、分片集群解android决的问题二、分片集群图解 分片集群特征如何解决的上述问题?(与哨兵模

C++作用域和标识符查找规则详解

《C++作用域和标识符查找规则详解》在C++中,作用域(Scope)和标识符查找(IdentifierLookup)是理解代码行为的重要概念,本文将详细介绍这些规则,并通过实例来说明它们的工作原理,需... 目录作用域标识符查找规则1. 普通查找(Ordinary Lookup)2. 限定查找(Qualif

Nginx Location映射规则总结归纳与最佳实践

《NginxLocation映射规则总结归纳与最佳实践》Nginx的location指令是配置请求路由的核心机制,其匹配规则直接影响请求的处理流程,下面给大家介绍NginxLocation映射规则... 目录一、Location匹配规则与优先级1. 匹配模式2. 优先级顺序3. 匹配示例二、Proxy_pa

Python程序打包exe,单文件和多文件方式

《Python程序打包exe,单文件和多文件方式》:本文主要介绍Python程序打包exe,单文件和多文件方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python 脚本打成exe文件安装Pyinstaller准备一个ico图标打包方式一(适用于文件较少的程