URP.Telemetry (urp v0.10.0)

Copy Markdown

Telemetry events emitted by URP.

Events

[:urp, :call, :stop]

Emitted after every pool checkout completes (all operations go through URP.Pool.do_checkout/5).

Measurements (in :native time units)

KeyDescription
:total_timeWall time from checkout request to work completion
:queue_timeTime spent waiting for a pool connection
:service_timeTime spent doing work on the connection

Use System.convert_time_unit/3 to convert to milliseconds or microseconds:

System.convert_time_unit(queue_time, :native, :millisecond)

Metadata

KeyTypeDescription
:operationatomThe operation performed (e.g. :convert, :version, :filters)
:pooltermThe pool name or pid
:result:ok | :errorWhether the operation succeeded

Example handler

:telemetry.attach(
  "urp-logger",
  [:urp, :call, :stop],
  fn event, measurements, metadata, _config ->
    total_ms = System.convert_time_unit(measurements.total_time, :native, :millisecond)
    queue_ms = System.convert_time_unit(measurements.queue_time, :native, :millisecond)

    Logger.info(
      "[URP] #{metadata.operation} #{metadata.result} " <>
        "total=#{total_ms}ms queue=#{queue_ms}ms"
    )
  end,
  nil
)