Module: Datadog::Contrib::ActiveSupport::Cache::Instrumentation::ReadMulti

Defined in:
lib/ddtrace/contrib/active_support/cache/instrumentation.rb

Overview

Defines instrumentation for ActiveSupport cache reading of multiple keys

Instance Method Summary collapse

Instance Method Details

#read_multi(*keys, &block) ⇒ Object



118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
# File 'lib/ddtrace/contrib/active_support/cache/instrumentation.rb', line 118

def read_multi(*keys, &block)
  payload = {
    action: Ext::RESOURCE_CACHE_MGET,
    keys: keys,
    tracing_context: {}
  }

  begin
    # process and catch cache exceptions
    Instrumentation.start_trace_cache(payload)
    super
  rescue Exception => e
    payload[:exception] = [e.class.name, e.message]
    payload[:exception_object] = e
    raise e
  end
ensure
  Instrumentation.finish_trace_cache_multi(payload)
end