Sha256: 55caa28fca86ee1ecd2325e51ebb50d5e48e5e13220d94dca60bab4fb1aefc1c
Contents?: true
Size: 1.48 KB
Versions: 1
Compression:
Stored size: 1.48 KB
Contents
# encoding: utf-8 # This file is distributed under New Relic's license terms. # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details. # frozen_string_literal: true module NewRelic # # 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. # # @api public class TracedThread < Thread # # 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: # ```ruby # NewRelic::TracedThread.new { execute_some_code } # ``` # # @api public def initialize(*args, &block) NewRelic::Agent.record_api_supportability_metric(:traced_thread) traced_block = create_traced_block(*args, &block) super(*args, &traced_block) end def create_traced_block(*args, &block) return block if NewRelic::Agent.config[:'instrumentation.thread.tracing'] # if this is on, don't double trace NewRelic::Agent::Tracer.thread_block_with_current_transaction(*args, &block) end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
newrelic_rpm-8.7.0 | lib/new_relic/traced_thread.rb |