From 6bf380a0e9847a979fbb200d6c3b4946deca73e6 Mon Sep 17 00:00:00 2001 From: Robert Mosolgo Date: Tue, 21 Nov 2023 14:48:24 -0500 Subject: [PATCH 1/4] Reduce allocations on GraphQL hot paths --- sdk/lib/opentelemetry/sdk/internal.rb | 9 +++++---- sdk/lib/opentelemetry/sdk/trace/span.rb | 10 +++++----- sdk/lib/opentelemetry/sdk/trace/tracer_provider.rb | 2 +- 3 files changed, 11 insertions(+), 10 deletions(-) diff --git a/sdk/lib/opentelemetry/sdk/internal.rb b/sdk/lib/opentelemetry/sdk/internal.rb index 9c9068b93e..f3fe3de01d 100644 --- a/sdk/lib/opentelemetry/sdk/internal.rb +++ b/sdk/lib/opentelemetry/sdk/internal.rb @@ -49,17 +49,18 @@ def valid_value?(value) end def valid_attributes?(owner, kind, attrs) - attrs.nil? || attrs.all? do |k, v| + attrs.nil? || attrs.each do |k, v| if !valid_key?(k) OpenTelemetry.handle_error(message: "invalid #{kind} attribute key type #{k.class} on span '#{owner}'") - false + break false elsif !valid_value?(v) OpenTelemetry.handle_error(message: "invalid #{kind} attribute value type #{v.class} for key '#{k}' on span '#{owner}'") - false + break false else - true end end + + true end end end diff --git a/sdk/lib/opentelemetry/sdk/trace/span.rb b/sdk/lib/opentelemetry/sdk/trace/span.rb index b706b70d2c..dccfc52956 100644 --- a/sdk/lib/opentelemetry/sdk/trace/span.rb +++ b/sdk/lib/opentelemetry/sdk/trace/span.rb @@ -297,7 +297,7 @@ def initialize(context, parent_context, parent_span, name, kind, parent_span_id, @total_recorded_events = 0 @total_recorded_links = links&.size || 0 @total_recorded_attributes = attributes&.size || 0 - @attributes = attributes.nil? ? nil : Hash[attributes] # We need a mutable copy of attributes. + @attributes = attributes trim_span_attributes(@attributes) @events = nil @links = trim_links(links, span_limits.link_count_limit, span_limits.link_attribute_count_limit) @@ -317,7 +317,7 @@ def initialize(context, parent_context, parent_span, name, kind, parent_span_id, # SpanData. @monotonic_start_timestamp = monotonic_now @realtime_start_timestamp = if parent_span.recording? - relative_realtime(parent_span.realtime_start_timestamp, parent_span.monotonic_start_timestamp) + relative_realtime(parent_span.realtime_start_timestamp, parent_span.monotonic_start_timestamp, @monotonic_start_timestamp) else realtime_now end @@ -419,15 +419,15 @@ def append_event(events, event) # rubocop:disable Metrics/CyclomaticComplexity, def relative_timestamp(timestamp) return time_in_nanoseconds(timestamp) unless timestamp.nil? - relative_realtime(realtime_start_timestamp, monotonic_start_timestamp) + relative_realtime(realtime_start_timestamp, monotonic_start_timestamp, monotonic_now) end def time_in_nanoseconds(timestamp) (timestamp.to_r * 1_000_000_000).to_i end - def relative_realtime(realtime_base, monotonic_base) - realtime_base + (monotonic_now - monotonic_base) + def relative_realtime(realtime_base, monotonic_base, now) + realtime_base + (now - monotonic_base) end def realtime_now diff --git a/sdk/lib/opentelemetry/sdk/trace/tracer_provider.rb b/sdk/lib/opentelemetry/sdk/trace/tracer_provider.rb index 790c6ba0f9..10a8ed8aea 100644 --- a/sdk/lib/opentelemetry/sdk/trace/tracer_provider.rb +++ b/sdk/lib/opentelemetry/sdk/trace/tracer_provider.rb @@ -141,7 +141,7 @@ def internal_start_span(name, kind, attributes, links, start_timestamp, parent_c if result.recording? && !@stopped trace_flags = result.sampled? ? OpenTelemetry::Trace::TraceFlags::SAMPLED : OpenTelemetry::Trace::TraceFlags::DEFAULT context = OpenTelemetry::Trace::SpanContext.new(trace_id: trace_id, span_id: span_id, trace_flags: trace_flags, tracestate: result.tracestate) - attributes = attributes&.merge(result.attributes) || result.attributes + attributes = attributes&.merge(result.attributes) || result.attributes.dup Span.new( context, parent_context, From 2432c70d3efa9eb72b6bb95785d00944f3fe77cb Mon Sep 17 00:00:00 2001 From: Robert Mosolgo Date: Tue, 21 Nov 2023 15:39:05 -0500 Subject: [PATCH 2/4] Update sdk/lib/opentelemetry/sdk/internal.rb Co-authored-by: Francis Bogsanyi --- sdk/lib/opentelemetry/sdk/internal.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sdk/lib/opentelemetry/sdk/internal.rb b/sdk/lib/opentelemetry/sdk/internal.rb index f3fe3de01d..2acd231a07 100644 --- a/sdk/lib/opentelemetry/sdk/internal.rb +++ b/sdk/lib/opentelemetry/sdk/internal.rb @@ -52,7 +52,7 @@ def valid_attributes?(owner, kind, attrs) attrs.nil? || attrs.each do |k, v| if !valid_key?(k) OpenTelemetry.handle_error(message: "invalid #{kind} attribute key type #{k.class} on span '#{owner}'") - break false + return false elsif !valid_value?(v) OpenTelemetry.handle_error(message: "invalid #{kind} attribute value type #{v.class} for key '#{k}' on span '#{owner}'") break false From 2c819f3ad58a5d18a728a5a998bfc63379c94cab Mon Sep 17 00:00:00 2001 From: Robert Mosolgo Date: Tue, 21 Nov 2023 15:39:13 -0500 Subject: [PATCH 3/4] Update sdk/lib/opentelemetry/sdk/internal.rb Co-authored-by: Francis Bogsanyi --- sdk/lib/opentelemetry/sdk/internal.rb | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/sdk/lib/opentelemetry/sdk/internal.rb b/sdk/lib/opentelemetry/sdk/internal.rb index 2acd231a07..fae806960c 100644 --- a/sdk/lib/opentelemetry/sdk/internal.rb +++ b/sdk/lib/opentelemetry/sdk/internal.rb @@ -55,8 +55,7 @@ def valid_attributes?(owner, kind, attrs) return false elsif !valid_value?(v) OpenTelemetry.handle_error(message: "invalid #{kind} attribute value type #{v.class} for key '#{k}' on span '#{owner}'") - break false - else + return false end end From 2f48c4dd25ddf6931211c41f125fbdb3e5c240c0 Mon Sep 17 00:00:00 2001 From: Francis Bogsanyi Date: Wed, 22 Nov 2023 14:15:33 -0500 Subject: [PATCH 4/4] Appease the cop --- sdk/lib/opentelemetry/sdk/trace/span.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sdk/lib/opentelemetry/sdk/trace/span.rb b/sdk/lib/opentelemetry/sdk/trace/span.rb index dccfc52956..3221b8ccdd 100644 --- a/sdk/lib/opentelemetry/sdk/trace/span.rb +++ b/sdk/lib/opentelemetry/sdk/trace/span.rb @@ -282,7 +282,7 @@ def to_span_data end # @api private - def initialize(context, parent_context, parent_span, name, kind, parent_span_id, span_limits, span_processors, attributes, links, start_timestamp, resource, instrumentation_scope) # rubocop:disable Metrics/CyclomaticComplexity, Metrics/MethodLength, Metrics/PerceivedComplexity + def initialize(context, parent_context, parent_span, name, kind, parent_span_id, span_limits, span_processors, attributes, links, start_timestamp, resource, instrumentation_scope) # rubocop:disable Metrics/MethodLength, Metrics/PerceivedComplexity super(span_context: context) @mutex = Mutex.new @name = name