Module: Datadog::Tracing::Contrib::DelayedJob::ServerInternalTracer::Worker

Defined in:
lib/datadog/tracing/contrib/delayed_job/server_internal_tracer/worker.rb

Overview

Trace when DelayedJob looks for a new job to work on

Instance Method Summary collapse

Instance Method Details

#reserve_jobObject



10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
# File 'lib/datadog/tracing/contrib/delayed_job/server_internal_tracer/worker.rb', line 10

def reserve_job
  configuration = Datadog.configuration.tracing[:delayed_job]

  Datadog::Tracing.trace(Ext::SPAN_RESERVE_JOB, service: configuration[:service_name]) do |span|
    span.span_type = Datadog::Tracing::Metadata::Ext::AppTypes::TYPE_WORKER

    span.set_tag(Contrib::Ext::Messaging::TAG_SYSTEM, Ext::TAG_COMPONENT)

    span.set_tag(Datadog::Tracing::Metadata::Ext::TAG_COMPONENT, Ext::TAG_COMPONENT)
    span.set_tag(Datadog::Tracing::Metadata::Ext::TAG_OPERATION, Ext::TAG_OPERATION_RESERVE_JOB)

    # Set analytics sample rate
    if Contrib::Analytics.enabled?(configuration[:analytics_enabled])
      Contrib::Analytics.set_sample_rate(span, configuration[:analytics_sample_rate])
    end

    super
  end
end