Class: OpenTelemetry::Exporter::Jaeger::AgentExporter
- Inherits:
-
Object
- Object
- OpenTelemetry::Exporter::Jaeger::AgentExporter
- Defined in:
- lib/opentelemetry/exporter/jaeger/agent_exporter.rb
Overview
An OpenTelemetry trace exporter that sends spans over UDP as Thrift Compact encoded Jaeger spans.
Instance Method Summary collapse
-
#export(span_data, timeout: nil) ⇒ Integer
Called to export sampled SDK::Trace::SpanData structs.
-
#initialize(host: ENV.fetch('OTEL_EXPORTER_JAEGER_AGENT_HOST', 'localhost'), port: ENV.fetch('OTEL_EXPORTER_JAEGER_AGENT_PORT', 6831), max_packet_size: 65_000) ⇒ AgentExporter
constructor
A new instance of AgentExporter.
-
#shutdown(timeout: nil) ⇒ Object
Called when SDK::Trace::Tracer#shutdown is called, if this exporter is registered to a SDK::Trace::Tracer object.
Constructor Details
#initialize(host: ENV.fetch('OTEL_EXPORTER_JAEGER_AGENT_HOST', 'localhost'), port: ENV.fetch('OTEL_EXPORTER_JAEGER_AGENT_PORT', 6831), max_packet_size: 65_000) ⇒ AgentExporter
Returns a new instance of AgentExporter.
16 17 18 19 20 21 22 23 24 25 26 |
# File 'lib/opentelemetry/exporter/jaeger/agent_exporter.rb', line 16 def initialize(host: ENV.fetch('OTEL_EXPORTER_JAEGER_AGENT_HOST', 'localhost'), port: ENV.fetch('OTEL_EXPORTER_JAEGER_AGENT_PORT', 6831), max_packet_size: 65_000) transport = Transport.new(host, port) protocol = ::Thrift::CompactProtocol.new(transport) @client = Thrift::Agent::Client.new(protocol) @max_packet_size = max_packet_size @shutdown = false @sizing_transport = SizingTransport.new @sizing_protocol = ::Thrift::CompactProtocol.new(@sizing_transport) end |
Instance Method Details
#export(span_data, timeout: nil) ⇒ Integer
Called to export sampled SDK::Trace::SpanData structs.
35 36 37 38 39 40 41 42 43 44 |
# File 'lib/opentelemetry/exporter/jaeger/agent_exporter.rb', line 35 def export(span_data, timeout: nil) return FAILURE if @shutdown start_time = Time.now encoded_batches(span_data) do |batch| return FAILURE if @shutdown || OpenTelemetry::Common::Utilities.maybe_timeout(timeout, start_time)&.zero? @client.emitBatch(batch) end end |
#shutdown(timeout: nil) ⇒ Object
Called when SDK::Trace::Tracer#shutdown is called, if this exporter is registered to a SDK::Trace::Tracer object.
51 52 53 |
# File 'lib/opentelemetry/exporter/jaeger/agent_exporter.rb', line 51 def shutdown(timeout: nil) @shutdown = true end |