opentelemetry-sdk 1.3.2 → 1.4.1
Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 30876b5f639b980b00d48fbae72e4b01850b3c57cafa01aa4dc5ca580be0918d
|
4
|
+
data.tar.gz: d002cb6584183e04b65a7b770bb75565bee3fe54396ade52714a009a26a5cb92
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 940facba296fde53952e694e465b7ab72cbbfabbeaa1e8bec8444476dcd57c6efd5227208021722d7130698eb33f0baf5d332594bac5f79ec946950b3c5231e3
|
7
|
+
data.tar.gz: 3b2f25a049880af16792a74ec5c35b3531555bff41f049ddf91422da7896f836a295c54419fc8e82abfe076cfd6fe003a0093a2a91319e65c246c00dc280e229
|
data/CHANGELOG.md
CHANGED
@@ -1,5 +1,13 @@
|
|
1
1
|
# Release History: opentelemetry-sdk
|
2
2
|
|
3
|
+
### v1.4.1 / 2024-03-21
|
4
|
+
|
5
|
+
* FIXED: ForwardingLogger should forward block param.
|
6
|
+
|
7
|
+
### v1.4.0 / 2024-01-25
|
8
|
+
|
9
|
+
* ADDED: Add spans to Trace::ExportError
|
10
|
+
|
3
11
|
### v1.3.2 / 2024-01-23
|
4
12
|
|
5
13
|
* FIXED: Reduce allocations on GraphQL hot paths
|
@@ -35,10 +35,10 @@ module OpenTelemetry
|
|
35
35
|
end
|
36
36
|
end
|
37
37
|
|
38
|
-
def add(severity, message = nil, progname = nil)
|
38
|
+
def add(severity, message = nil, progname = nil, &block)
|
39
39
|
return true if severity < @level
|
40
40
|
|
41
|
-
@logger.add(severity, message, progname)
|
41
|
+
@logger.add(severity, message, progname, &block)
|
42
42
|
end
|
43
43
|
|
44
44
|
def debug(progname = nil, &block)
|
@@ -80,7 +80,7 @@ module OpenTelemetry
|
|
80
80
|
lock do
|
81
81
|
reset_on_fork
|
82
82
|
n = spans.size + 1 - max_queue_size
|
83
|
-
if n
|
83
|
+
if n > 0
|
84
84
|
dropped_spans = spans.shift(n)
|
85
85
|
report_dropped_spans(dropped_spans, reason: 'buffer-full', function: __method__.to_s)
|
86
86
|
end
|
@@ -110,7 +110,7 @@ module OpenTelemetry
|
|
110
110
|
remaining_timeout = OpenTelemetry::Common::Utilities.maybe_timeout(timeout, start_time)
|
111
111
|
return TIMEOUT if remaining_timeout&.zero?
|
112
112
|
|
113
|
-
batch = snapshot.shift(@batch_size)
|
113
|
+
batch = snapshot.shift(@batch_size)
|
114
114
|
result_code = export_batch(batch, timeout: remaining_timeout)
|
115
115
|
return result_code unless result_code == SUCCESS
|
116
116
|
end
|
@@ -125,7 +125,7 @@ module OpenTelemetry
|
|
125
125
|
dropped_spans = snapshot.shift(n)
|
126
126
|
report_dropped_spans(dropped_spans, reason: 'buffer-full', function: __method__.to_s)
|
127
127
|
end
|
128
|
-
spans.unshift(snapshot) unless snapshot.empty?
|
128
|
+
spans.unshift(*snapshot) unless snapshot.empty?
|
129
129
|
@condition.signal if spans.size > max_queue_size / 2
|
130
130
|
end
|
131
131
|
end
|
@@ -162,7 +162,7 @@ module OpenTelemetry
|
|
162
162
|
@condition.wait(@mutex, @delay_seconds) while spans.empty? && @keep_running
|
163
163
|
return unless @keep_running
|
164
164
|
|
165
|
-
|
165
|
+
spans.shift(@batch_size)
|
166
166
|
end
|
167
167
|
|
168
168
|
@metrics_reporter.observe_value('otel.bsp.buffer_utilization', value: spans.size / max_queue_size.to_f)
|
@@ -183,24 +183,25 @@ module OpenTelemetry
|
|
183
183
|
OpenTelemetry.handle_error(exception: e, message: 'unexpected error in BatchSpanProcessor#reset_on_fork')
|
184
184
|
end
|
185
185
|
|
186
|
-
def export_batch(
|
186
|
+
def export_batch(span_array, timeout: @exporter_timeout_seconds)
|
187
|
+
batch = span_array.map(&:to_span_data)
|
187
188
|
result_code = @export_mutex.synchronize { @exporter.export(batch, timeout: timeout) }
|
188
|
-
report_result(result_code,
|
189
|
+
report_result(result_code, span_array)
|
189
190
|
result_code
|
190
191
|
rescue StandardError => e
|
191
|
-
report_result(FAILURE,
|
192
|
+
report_result(FAILURE, span_array)
|
192
193
|
@metrics_reporter.add_to_counter('otel.bsp.error', labels: { 'reason' => e.class.to_s })
|
193
194
|
FAILURE
|
194
195
|
end
|
195
196
|
|
196
|
-
def report_result(result_code,
|
197
|
+
def report_result(result_code, span_array)
|
197
198
|
if result_code == SUCCESS
|
198
199
|
@metrics_reporter.add_to_counter('otel.bsp.export.success')
|
199
|
-
@metrics_reporter.add_to_counter('otel.bsp.exported_spans', increment:
|
200
|
+
@metrics_reporter.add_to_counter('otel.bsp.exported_spans', increment: span_array.size)
|
200
201
|
else
|
201
|
-
OpenTelemetry.handle_error(exception: ExportError.new(
|
202
|
+
OpenTelemetry.handle_error(exception: ExportError.new(span_array))
|
202
203
|
@metrics_reporter.add_to_counter('otel.bsp.export.failure')
|
203
|
-
report_dropped_spans(
|
204
|
+
report_dropped_spans(span_array, reason: 'export-failure')
|
204
205
|
end
|
205
206
|
end
|
206
207
|
|
@@ -208,10 +209,6 @@ module OpenTelemetry
|
|
208
209
|
@metrics_reporter.add_to_counter('otel.bsp.dropped_spans', increment: dropped_spans.size, labels: { 'reason' => reason, OpenTelemetry::SemanticConventions::Trace::CODE_FUNCTION => function }.compact)
|
209
210
|
end
|
210
211
|
|
211
|
-
def fetch_batch
|
212
|
-
spans.shift(@batch_size).map!(&:to_span_data)
|
213
|
-
end
|
214
|
-
|
215
212
|
def lock
|
216
213
|
@mutex.synchronize do
|
217
214
|
yield
|
@@ -10,7 +10,19 @@ module OpenTelemetry
|
|
10
10
|
# The Export module contains the built-in exporters and span processors for the OpenTelemetry
|
11
11
|
# reference implementation.
|
12
12
|
module Export
|
13
|
-
|
13
|
+
# Raised when an export fails; spans are available via :spans accessor
|
14
|
+
class ExportError < OpenTelemetry::Error
|
15
|
+
# Returns the {Span} array for this exception
|
16
|
+
#
|
17
|
+
# @return [Array<OpenTelemetry::SDK::Trace::Span>]
|
18
|
+
attr_reader :spans
|
19
|
+
|
20
|
+
# @param [Array<OpenTelemetry::SDK::Trace::Span>] spans the array of spans that failed to export
|
21
|
+
def initialize(spans)
|
22
|
+
super("Unable to export #{spans.size} spans")
|
23
|
+
@spans = spans
|
24
|
+
end
|
25
|
+
end
|
14
26
|
|
15
27
|
# Result codes for the SpanExporter#export method and the SpanProcessor#force_flush and SpanProcessor#shutdown methods.
|
16
28
|
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: opentelemetry-sdk
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.
|
4
|
+
version: 1.4.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- OpenTelemetry Authors
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2024-
|
11
|
+
date: 2024-03-26 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: opentelemetry-api
|
@@ -294,10 +294,10 @@ homepage: https://github.com/open-telemetry/opentelemetry-ruby
|
|
294
294
|
licenses:
|
295
295
|
- Apache-2.0
|
296
296
|
metadata:
|
297
|
-
changelog_uri: https://open-telemetry.github.io/opentelemetry-ruby/opentelemetry-sdk/v1.
|
297
|
+
changelog_uri: https://open-telemetry.github.io/opentelemetry-ruby/opentelemetry-sdk/v1.4.1/file.CHANGELOG.html
|
298
298
|
source_code_uri: https://github.com/open-telemetry/opentelemetry-ruby/tree/main/sdk
|
299
299
|
bug_tracker_uri: https://github.com/open-telemetry/opentelemetry-ruby/issues
|
300
|
-
documentation_uri: https://open-telemetry.github.io/opentelemetry-ruby/opentelemetry-sdk/v1.
|
300
|
+
documentation_uri: https://open-telemetry.github.io/opentelemetry-ruby/opentelemetry-sdk/v1.4.1
|
301
301
|
post_install_message:
|
302
302
|
rdoc_options: []
|
303
303
|
require_paths:
|