estimateGas
Generates and returns an estimate of how much gas is necessary to allow the transaction to complete. The transaction will not be added to the blockchain. Note that the estimate may be significantly more than the amount of gas actually used by the transaction, for a variety of reasons including EVM mechanics and node performance.
Method Limitations
To prevent abusive of the API, the gas
parameter to eth_estimateGas
and eth_call
are capped at 10x (1000%) the current block gas limit. You can recreate this behavior in your local test environment (ganache, besu, geth, or other client) via the rpc.gascap
command-line option.
REQUEST
HEADER
REQUEST PAYLOAD
TRANSACTION CALL OBJECT
[required]from
: [optional] 20 Bytes - The address the transaction is sent from.to
: 20 Bytes - The address the transaction is directed to.gas
: [optional] Integer of the gas provided for the transaction execution. eth_estimateGas consumes zero gas, but this parameter may be needed by some executions.gasPrice
: [optional] Integer of the gasPrice used for each paid gasvalue
: [optional] Integer of the value sent with this transactiondata
: [optional] Hash of the method signature and encoded parameters. For details see Ethereum Contract ABI
If no gas limit is specified geth uses the block gas limit from the pending block as an upper bound. As a result the returned estimate might not be enough to executed the call/transaction when the amount of gas is higher than the pending block gas limit.
EXAMPLE
RESPONSE
RESULT FIELDS
GAS USED
- the amount of gas used.
BODY
On Mainnet, if this call causes the EVM to execute a REVERT
operation, an error response of the following form is returned, with the revert reason pre-decoded as a string.
Last updated