From 1bcb3d8cc2a7de390f50eaffa2244e86b6d7429d Mon Sep 17 00:00:00 2001 From: Alex Antonov Date: Wed, 27 Mar 2019 11:20:05 -0500 Subject: [PATCH] Added support for configuring trace headers for DataDog tracing --- pkg/tracing/datadog/datadog.go | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/pkg/tracing/datadog/datadog.go b/pkg/tracing/datadog/datadog.go index 39635375e..42c0d3558 100644 --- a/pkg/tracing/datadog/datadog.go +++ b/pkg/tracing/datadog/datadog.go @@ -15,10 +15,14 @@ const Name = "datadog" // Config provides configuration settings for a datadog tracer type Config struct { - LocalAgentHostPort string `description:"Set datadog-agent's host:port that the reporter will used. Defaults to localhost:8126" export:"false"` - GlobalTag string `description:"Key:Value tag to be set on all the spans." export:"true"` - Debug bool `description:"Enable DataDog debug." export:"true"` - PrioritySampling bool `description:"Enable priority sampling. When using distributed tracing, this option must be enabled in order to get all the parts of a distributed trace sampled."` + LocalAgentHostPort string `description:"Set datadog-agent's host:port that the reporter will used. Defaults to localhost:8126" export:"false"` + GlobalTag string `description:"Key:Value tag to be set on all the spans." export:"true"` + Debug bool `description:"Enable DataDog debug." export:"true"` + PrioritySampling bool `description:"Enable priority sampling. When using distributed tracing, this option must be enabled in order to get all the parts of a distributed trace sampled."` + TraceIDHeaderName string `description:"Specifies the header name that will be used to store the trace ID." export:"true"` + ParentIDHeaderName string `description:"Specifies the header name that will be used to store the parent ID." export:"true"` + SamplingPriorityHeaderName string `description:"Specifies the header name that will be used to store the sampling priority." export:"true"` + BagagePrefixHeaderName string `description:"specifies the header name prefix that will be used to store baggage items in a map." export:"true"` } // Setup sets up the tracer @@ -35,6 +39,12 @@ func (c *Config) Setup(serviceName string) (opentracing.Tracer, io.Closer, error datadog.WithServiceName(serviceName), datadog.WithGlobalTag(tag[0], value), datadog.WithDebugMode(c.Debug), + datadog.WithPropagator(datadog.NewPropagator(&datadog.PropagatorConfig{ + TraceHeader: c.TraceIDHeaderName, + ParentHeader: c.ParentIDHeaderName, + PriorityHeader: c.SamplingPriorityHeaderName, + BaggagePrefix: c.BagagePrefixHeaderName, + })), } if c.PrioritySampling { opts = append(opts, datadog.WithPrioritySampling())