Class: NewRelic::TracedThread
- Inherits:
-
Thread
- Object
- Thread
- NewRelic::TracedThread
- Defined in:
- lib/new_relic/traced_thread.rb
Overview
This class allows the current transaction to be passed to a Thread so that nested segments can be created from the operations performed within the Thread’s block. To have the New Relic Ruby agent automatically trace all of your applications threads, enable the instrumentation.thread.tracing
configuration option in your newrelic.yml.
Note: disabling the configuration option instrumentation.thread
while using this class can cause incorrectly nested spans.
Instance Method Summary collapse
-
#initialize(*args, &block) ⇒ TracedThread
constructor
Creates a new Thread whose work will be traced by New Relic.
Constructor Details
#initialize(*args, &block) ⇒ TracedThread
Creates a new Thread whose work will be traced by New Relic. Use this class as a replacement for the native Thread class. Example: Instead of using Thread.new
, use:
NewRelic::TracedThread.new { execute_some_code }
23 24 25 26 27 |
# File 'lib/new_relic/traced_thread.rb', line 23 def initialize(*args, &block) NewRelic::Agent.record_api_supportability_metric(:traced_thread) traced_block = create_traced_block(&block) super(*args, &traced_block) end |