Configure the Datadog Tracing Library

This page describes configuration options that behave consistently across all languages. To view these common configuration options, see Common configuration options.

For configuration options specific to your programming language, choose your language from the options below:

Java
Python
Ruby
Go
Node.js
PHP
C++
.Net
.Net

To instrument an application written in a language that does not yet have official library support, see the list of community tracing libraries.

Common configuration options

The following configuration options behave consistently across the latest versions of all Datadog SDKs, unless otherwise noted:

Traces

DD_TRACE_<INTEGRATION>_ENABLED
Default: true
Supported Input: Boolean
Caveats: Not supported in Go; Some Java integrations are disabled by default.
Description: Enables or disables instrumentation for the specified <INTEGRATION>. The integration name must be in uppercase (for example, DD_TRACE_KAFKA_ENABLED=true)
DD_TRACE_RATE_LIMIT
Default: 100
Supported Input: A positive integer
Caveats: 200 is the default value of DD_TRACE_RATE_LIMIT in C++
Description: Sets the maximum number of traces to sample per second; applies only when either DD_TRACE_SAMPLING_RULES or DD_TRACE_SAMPLE_RATE is set.
DD_TRACE_HEADER_TAGS
Default: null
Supported Input: A comma-separated string representing a list of case-insensitive HTTP headers, with an optional mapping to a custom tag name. Example: User-Agent:my-user-agent,Content-Type.
Description: Automatically apply specified HTTP headers as span tags. If a custom tag name is not specified, the tag key defaults to http.request.headers.<normalized-header-name> for request headers and http.response.headers.<normalized-header-name> for response headers.
DD_TRACE_ENABLED
Default: true
Supported Input: Boolean
Description: Enables or disables sending traces from the application.
DD_TRACE_OBFUSCATION_QUERY_STRING_REGEXP
Default:
(?i)(?:(?:"|%22)?)(?:(?:old[-_]?|new[-_]?)?p(?:ass)?w(?:or)?d(?:1|2)?|pass(?:[-_]?phrase)?|secret|(?:api[-_]?|private[-_]?|public[-_]?|access[-_]?|secret[-_]?|app(?:lication)?[-_]?)key(?:[-_]?id)?|token|consumer[-_]?(?:id|key|secret)|sign(?:ed|ature)?|auth(?:entication|orization)?)(?:(?:\s|%20)*(?:=|%3D)[^&]+|(?:"|%22)(?:\s|%20)*(?::|%3A)(?:\s|%20)*(?:"|%22)(?:%2[^2]|%[^2]|[^"%])+(?:"|%22))|(?:bearer(?:\s|%20)+[a-z0-9._\-]+|token(?::|%3A)[a-z0-9]{13}|gh[opsu]_[0-9a-zA-Z]{36}|ey[I-L](?:[\w=-]|%3D)+\.ey[I-L](?:[\w=-]|%3D)+(?:\.(?:[\w.+/=-]|%3D|%2F|%2B)+)?|-{5}BEGIN(?:[a-z\s]|%20)+PRIVATE(?:\s|%20)KEY-{5}[^\-]+-{5}END(?:[a-z\s]|%20)+PRIVATE(?:\s|%20)KEY(?:-{5})?(?:\n|%0A)?|(?:ssh-(?:rsa|dss)|ecdsa-[a-z0-9]+-[a-z0-9]+)(?:\s|%20|%09)+(?:[a-z0-9/.+]|%2F|%5C|%2B){100,}(?:=|%3D)*(?:(?:\s|%20|%09)+[a-z0-9._-]+)?)
Supported Input: A regex string
Description: Applies a regex to redact sensitive data from query strings on incoming HTTP requests. The default regex matches various sensitive data patterns, including passwords, tokens, API keys, private keys, and authorization terms. Matches are replaced with <redacted>. If an empty string is passed, no obfuscation occurs. The resulting value is reported in the http.url tag.

Diagnostics

DD_TRACE_LOG_DIRECTORY
Default: Varies by SDK, environment, and runtime. Please read more in the specific configuration page above for your chosen language
Supported Input: A valid full or relative directory path that exists on the system
Caveats: Not supported in Java, Node.js, Ruby, Python
Description: Specifies the directory where tracer log files should be routed. If the directory does not exist, the SDK falls back to its default diagnostic logging method.

Agent

DD_TRACE_AGENT_URL
Default: http://localhost:8126
Supported Input: A string representing an HTTP or UDS url
Description: The URL for connecting the tracer to the Datadog agent. Valid URL schemas include http:// and unix:// (UNIX Domain Sockets). This value takes precedence over DD_AGENT_HOST and DD_TRACE_AGENT_PORT if set.

Unified Service Tagging

DD_VERSION
Default: null
Supported Input: A string representing an application version
Caveats: Node.js defaults to the version number from package.json
Description: Adds a version tag to all spans, except for Inferred services
DD_SERVICE
Default: null, the SDK tries to automatically determine a service name
Supported Input: A string representing an application service name
Description: Sets the default service name used for most spans. SDKs may set a different service name for inferred services. Integration spans may use their own default names, which can differ from the value specified in DD_SERVICE
DD_ENV
Default: null
Supported Input: A string representing an application environment name (for example, prod, dev)
Description: Adds an environment tag to all spans generated by the tracer instance.

Integrations

DD_TRACE_HTTP_CLIENT_ERROR_STATUSES
Default: 400-499
Supported Input: A comma-separated string of the form from-to, where from and to are integers. Singular values are also accepted (for example, 400-403,405,410-499).
Caveats: Not supported in Node.js
Description: Defines the inclusive range of status codes to be considered as errors on automatically collected HTTP client spans. Only the values within the specified range are considered errors.
DD_TRACE_HTTP_SERVER_ERROR_STATUSES
Default: 500-599
Supported Input: A comma-separated string of the form from-to, where from and to are integers. Singular values are also accepted (for example, 400-403,405,410-499).
Caveats: Not supported in Node.js
Description: Defines the inclusive range of status codes to be considered errors on http.server span kinds. Only the values within the specified range are considered errors.
DD_TRACE_HTTP_CLIENT_TAG_QUERY_STRING
Default: true
Supported Input: Boolean
Caveats: Not supported in Node.js; Disabled by default in Go
Description: Enables or disables the inclusion of the query string in the http.url span tag value for automatically collected HTTP spans.
DD_TRACE_CLIENT_IP_HEADER
Default: null
Supported Input: Any non-empty string
Description: Configures a custom header name from which to source the http.client_ip tag value. If this variable is set, all other IP-related headers are ignored (for example, setting DD_TRACE_CLIENT_IP_HEADER=custom-ip-header and including the header custom-ip-header: 5.6.7.9 in a request results in a span tagged with "http.client_ip": "5.6.7.9"). If an empty string or null value is passed, IP headers are queried in this order:
  • x-forwarded-for
  • x-real-ip
  • true-client-ip
  • x-client-ip
  • x-forwarded
  • forwarded-for
  • x-cluster-client-ip
  • fastly-client-ip
  • cf-connecting-ip
  • cf-connecting-ipv6