# frozen_string_literal: true # Copyright 2019 OpenTelemetry Authors # # SPDX-License-Identifier: Apache-2.0 module OpenTelemetry module SDK module Trace # {TracerFactory} is the SDK implementation of {OpenTelemetry::Trace::TracerFactory}. class TracerFactory < OpenTelemetry::Trace::TracerFactory Key = Struct.new(:name, :version) private_constant(:Key) attr_accessor :active_trace_config attr_reader :active_span_processor attr_reader :stopped alias stopped? stopped # Returns a new {TracerFactory} instance. # # @return [TracerFactory] def initialize @mutex = Mutex.new @registry = {} @active_span_processor = NoopSpanProcessor.instance @active_trace_config = Config::TraceConfig::DEFAULT @registered_span_processors = [] @stopped = false end # Returns a {Tracer} instance. # # @param [optional String] name Instrumentation package name # @param [optional String] version Instrumentation package version # # @return [Tracer] def tracer(name = nil, version = nil) name ||= '' version ||= '' @mutex.synchronize { @registry[Key.new(name, version)] ||= Tracer.new(name, version) } end # Attempts to stop all the activity for this {Tracer}. Calls # SpanProcessor#shutdown for all registered SpanProcessors. # # This operation may block until all the Spans are processed. Must be # called before turning off the main application to ensure all data are # processed and exported. # # After this is called all the newly created {Span}s will be no-op. def shutdown @mutex.synchronize do if @stopped OpenTelemetry.logger.warn('calling Tracer#shutdown multiple times.') return end @active_span_processor.shutdown @stopped = true end end # Adds a new SpanProcessor to this {Tracer}. # # Any registered processor causes overhead, consider to use an # async/batch processor especially for span exporting, and export to # multiple backends using the # {io.opentelemetry.sdk.trace.export.MultiSpanExporter}. # # @param span_processor the new SpanProcessor to be added. def add_span_processor(span_processor) @mutex.synchronize do if @stopped OpenTelemetry.logger.warn('calling Tracer#add_span_processor after shutdown.') return end @registered_span_processors << span_processor @active_span_processor = MultiSpanProcessor.new(@registered_span_processors) end end end end end end