[Trace] debug_traceBlockByNumberRange
Returns the structured logs created during the execution of EVM between two blocks (including start) as a JSON object. That is, the result of tracing for a total of end-start+1 blocks is returned.
NOTE: Don't trace too many blocks at the same time as it can overuse machine resources.
JSONRPC: debug_traceBlockByNumberRange
Request
- application/json
Body
Array [
- StartBlock
- EndBlock
- TracingOptions
]
params
object[]
anyOf
Tracing start block number.
number
Tracing end block number.
number
Setting this to true will disable storage capture in the null (structLog) tracer (default: false).
Setting this to true will disable memory capture in the null (structLog) tracer (default: false).
Setting this to true will disable stack capture in the null (structLog) tracer (default: false).
Overrides the default timeout of 5 seconds for trace-enabled EVM execution. A duration string can be anything that is accepted by Go time.ParseDuration function such as "10s" or "300ms".
Possible values: [null
, 4byteTracer
, callTracer
, fastCallTracer
, evmdisTracer
, noopTracer
, opcountTracer
, prestateTracer
, revertTracer
, unigramTracer
, bigramTracer
, trigramTracer
, custom javascript tracer code
]
If this field is empty or null, then the structLog tracer is used where the execution of every opcode is shown in detail. This null tracer is extremely heavy and usually too verbose for any debugging purpose, so it is advised to use other predefined tracers. This field can be the name of one of the predefined tracers shown below.
Tracer Name | Description |
---|---|
4byteTracer | traces 4-byte solidity function signatures. |
callTracer | a slow version of fastCallTracer. It is deprecated in favor of fastCallTracer. |
fastCallTracer | traces internal contract calls, gas usage, and call results. |
evmdisTracer | returns information needed to perform evmdis-style disassembly. |
noopTracer | is a template tracer that does nothing. |
opcountTracer | is a sample tracer that counts the executed opcode. |
prestateTracer | returns information needed to construct a custom local genesis state that this transaction can run on. |
revertTracer | returns the revert reason, or an empty string if the transaction has not reverted. |
unigramTracer | counts the occurrence of each opcode. |
bigramTracer | counts the occurrence of two consecutive opcodes. |
trigramTracer | counts the occurrence of three consecutive opcodes. |
Otherwise this field is interpreted as a piece of javascript code. You can find more about custom JS tracer here and here. Below is an example custom tracer that prints the gasUsed after each opcode "{gasUsed: [], step: function(log) { this.gasUsed.push(log.getGas()); }, result: function() { return this.gasUsed; }, fault: function() {}}"
. Note that some nodes with --rpc.unsafe-debug.disable
option will prohibit custom tracer.