본문으로 건너뛰기
이 페이지는 영어로 된 기계 번역을 사용하므로 오류나 불명확한 언어가 포함될 수 있습니다. 가장 정확한 정보는 영어 원문을 참조하시기 바랍니다. 잦은 업데이트로 인해 일부 콘텐츠는 원래 영어로 되어 있을 수 있습니다. Crowdin에서 이 페이지의 번역을 개선하는 데 동참하여 도움을 주세요. (Crowdin translation page, Contributing guide)

[Trace] debug_traceBlockByHash

Similar to debug_traceBlock, traceBlockByHash accepts a block hash and will replay the block that is already present in the database.

JSONRPC: debug_traceBlockByHash

Request

Body

    params

    undefined[]

  • Array [

  • BlockHash 32-byte DATA

    the block hash

    TracingOptions

    object

    disableStorage boolean

    Setting this to true will disable storage capture in the null (structLog) tracer (default: false).

    disableMemory boolean

    Setting this to true will disable memory capture in the null (structLog) tracer (default: false).

    disableStack boolean

    Setting this to true will disable stack capture in the null (structLog) tracer (default: false).

    timeout string

    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".

    tracer string

    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 NameDescription
    4byteTracertraces 4-byte solidity function signatures.
    callTracera slow version of fastCallTracer. It is deprecated in favor of fastCallTracer.
    fastCallTracertraces internal contract calls, gas usage, and call results.
    evmdisTracerreturns information needed to perform evmdis-style disassembly.
    noopTraceris a template tracer that does nothing.
    opcountTraceris a sample tracer that counts the executed opcode.
    prestateTracerreturns information needed to construct a custom local genesis state that this transaction can run on.
    revertTracerreturns the revert reason, or an empty string if the transaction has not reverted.
    unigramTracercounts the occurrence of each opcode.
    bigramTracercounts the occurrence of two consecutive opcodes.
    trigramTracercounts 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.

  • ]

Responses

The structured logs created during the execution of KLVM.

Schema

    error

    object

    code int64required

    A Number that indicates the error type that occurred. This MUST be an integer.

    codemessagedescription
    -32700Parse errorinvalid JSON was received by the server. An error occurred on the server while parsing the JSON text.
    -32602Invalid paramsInvalid method parameter(s).
    message string

    A String providing a short description of the error. The message SHOULD be limited to a concise single sentence.

    data string

    A Primitive or Structured value that contains additional information about the error. This may be omitted. The value of this member is defined by the Server (e.g. detailed error information, nested errors etc.).

    result

    object[]

    The structured logs created during the execution of KLVM.

  • Array [

  • failed boolean
    gas integer
    returnValue string
    structLogs object[]
  • ]

Loading...
페이지를 개선해 주세요