Class: Datadog::Contrib::Sidekiq::ClientTracer

Inherits:
Object
  • Object
show all
Includes:
Tracing
Defined in:
lib/ddtrace/contrib/sidekiq/client_tracer.rb

Overview

Tracer is a Sidekiq client-side middleware which traces job enqueues/pushes

Instance Method Summary collapse

Constructor Details

#initialize(options = {}) ⇒ ClientTracer

Returns a new instance of ClientTracer.



11
12
13
14
# File 'lib/ddtrace/contrib/sidekiq/client_tracer.rb', line 11

def initialize(options = {})
  super
  @sidekiq_service = options[:client_service_name] || configuration[:client_service_name]
end

Instance Method Details

#call(worker_class, job, queue, redis_pool) ⇒ Object

Client middleware arguments are documented here:

https://github.com/mperham/sidekiq/wiki/Middleware#client-middleware


18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
# File 'lib/ddtrace/contrib/sidekiq/client_tracer.rb', line 18

def call(worker_class, job, queue, redis_pool)
  resource = job_resource(job)

  @tracer.trace(Ext::SPAN_PUSH, service: @sidekiq_service) do |span|
    span.resource = resource
    # Set analytics sample rate
    if Contrib::Analytics.enabled?(configuration[:analytics_enabled])
      Contrib::Analytics.set_sample_rate(span, configuration[:analytics_sample_rate])
    end
    span.set_tag(Ext::TAG_JOB_ID, job['jid'])
    span.set_tag(Ext::TAG_JOB_QUEUE, job['queue'])
    span.set_tag(Ext::TAG_JOB_WRAPPER, job['class']) if job['wrapped']

    yield
  end
end