Module: Datadog::Tracing::Contrib::Rack::TraceProxyMiddleware
- Defined in:
- lib/datadog/tracing/contrib/rack/trace_proxy_middleware.rb
Overview
Module to create virtual proxy span
Class Method Summary collapse
Class Method Details
permalink .call(env, configuration) ⇒ Object
[View source]
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
# File 'lib/datadog/tracing/contrib/rack/trace_proxy_middleware.rb', line 16 def call(env, configuration) return yield unless configuration[:request_queuing] # parse the request queue time start_time = Contrib::Rack::QueueTime.get_request_start(env) return yield unless start_time = { service: configuration[:web_service_name], start_time: start_time, type: Tracing::Metadata::Ext::HTTP::TYPE_PROXY } request_span = Tracing.trace(Ext::SPAN_HTTP_PROXY_REQUEST, **) request_span.set_tag(Tracing::Metadata::Ext::TAG_COMPONENT, Ext::TAG_COMPONENT_HTTP_PROXY) request_span.set_tag(Tracing::Metadata::Ext::TAG_OPERATION, Ext::TAG_OPERATION_HTTP_PROXY_REQUEST) request_span.set_tag(Tracing::Metadata::Ext::TAG_KIND, Tracing::Metadata::Ext::SpanKind::TAG_PROXY) queue_span = Tracing.trace(Ext::SPAN_HTTP_PROXY_QUEUE, **) queue_span.set_tag(Tracing::Metadata::Ext::TAG_COMPONENT, Ext::TAG_COMPONENT_HTTP_PROXY) queue_span.set_tag(Tracing::Metadata::Ext::TAG_OPERATION, Ext::TAG_OPERATION_HTTP_PROXY_QUEUE) queue_span.set_tag(Tracing::Metadata::Ext::TAG_KIND, Tracing::Metadata::Ext::SpanKind::TAG_PROXY) Contrib::Analytics.set_measured(queue_span) # finish the `queue` span now to record only the time spent *in queue*, # excluding the time spent processing the request itself queue_span.finish yield.tap { request_span.finish } end |