Sha256: 3f89599ffeb7ed8f0efad5412b9ec34e09abfdf6b051e33a008c2f1df9cc0e86
Contents?: true
Size: 1.91 KB
Versions: 2
Compression:
Stored size: 1.91 KB
Contents
require_relative '../../metadata/ext' require_relative '../analytics' require_relative 'ext' require_relative 'tracing' module Datadog module Tracing module Contrib module Sidekiq # Tracer is a Sidekiq client-side middleware which traces job enqueues/pushes class ClientTracer include Tracing def initialize(options = {}) @sidekiq_service = options[:client_service_name] || configuration[:client_service_name] end # Client middleware arguments are documented here: # https://github.com/mperham/sidekiq/wiki/Middleware#client-middleware def call(worker_class, job, queue, redis_pool) resource = job_resource(job) Datadog::Tracing.trace(Ext::SPAN_PUSH, service: @sidekiq_service) do |span| span.resource = resource 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_PUSH) span.set_tag( Datadog::Tracing::Metadata::Ext::TAG_KIND, Datadog::Tracing::Metadata::Ext::SpanKind::TAG_PRODUCER ) # 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 private def configuration Datadog.configuration.tracing[:sidekiq] end end end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
ddtrace-1.10.1 | lib/datadog/tracing/contrib/sidekiq/client_tracer.rb |
ddtrace-1.10.0 | lib/datadog/tracing/contrib/sidekiq/client_tracer.rb |