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 |