Configuring the Go Tracing Library
이 페이지는 아직 영어로 제공되지 않습니다. 번역 작업 중입니다.
현재 번역 프로젝트에 대한 질문이나 피드백이 있으신 경우
 언제든지 연락주시기 바랍니다.After you set up the tracing library with your code, configure the Agent to collect APM data, and activate the Go integration, start the tracer and configure the library as desired. Note: This documentation uses v2 of the Go tracer, which Datadog recommends for all users. If you are using v1, see the migration guide to upgrade to v2.
Datadog recommends using DD_ENV, DD_SERVICE, and DD_VERSION to set env, service, and version for your services.
Read the Unified Service Tagging documentation for recommendations on how to configure these environment variables. These variables are available for versions 1.24.0+ of the Go tracer.
You may also elect to provide env, service, and version through the tracer’s API:
package main
import (
    "github.com/DataDog/dd-trace-go/v2/ddtrace/tracer"
)
func main() {
    tracer.Start(
        tracer.WithEnv("prod"),
        tracer.WithService("test-go"),
        tracer.WithServiceVersion("abc123"),
    )
    // When the tracer is stopped, it will flush everything it has to the Datadog Agent before quitting.
    // Make sure this line stays in your main function.
    defer tracer.Stop()
    // If you expect your application to be shut down by SIGTERM (for example, a container in Kubernetes),
    // you might want to listen for that signal and explicitly stop the tracer to ensure no data is lost
    sigChan := make(chan os.Signal, 1)
    signal.Notify(sigChan, syscall.SIGTERM)
    go func() {
        <-sigChan
        tracer.Stop()
    }()
}
The Go tracer supports additional environment variables and functions for configuration.
See all available options in the configuration documentation (or configuration documentation v1).
Unified service tagging
- DD_VERSION
- Set the application’s version, for example: 1.2.3,6c44da20,2020.02.13
- DD_SERVICE
- The service name to be used for this application.
- DD_ENV
- Set the application’s environment, for example: prod, pre-prod, staging.
Traces
- DD_TRACE_ENABLED
- Default: true
 Enable web framework and library instrumentation. When false, the application code doesn’t generate any traces.
 See also DD_APM_TRACING_ENABLED.
- DD_TRACE_AGENT_PORT
- Default: 8126
 Overrides the default trace Agent port for Datadog trace submission. Ignored ifDD_TRACE_AGENT_URLis set. If the Agent configuration setsreceiver_portorDD_APM_RECEIVER_PORTto something other than the default8126, then the library configurationDD_DOGSTATSD_PORTmust match it.
- DD_TRACE_AGENT_URL
- Default: null
 Override the Agent URL used for trace submission. Supportshttp://,https://, andunix://protocols. Takes precedence overDD_AGENT_HOSTandDD_TRACE_AGENT_PORTif set.
- DD_TRACE_RATE_LIMIT
- Maximum number of spans to sample per-second, per-Go process. Defaults to 100 when DD_TRACE_SAMPLE_RATE is set. Otherwise, delegates rate limiting to the Datadog Agent.
- DD_TRACE_STARTUP_LOGS
- Default: true
 Enable startup configuration and the diagnostic log.
- DD_TRACE_DEBUG
- Default: false
 Enable debug logging in the tracer.
- DD_SERVICE_MAPPING
- Default: null
 Dynamically rename services through configuration. Services can be separated by commas or spaces, for example:mysql:mysql-service-name,postgres:postgres-service-name,mysql:mysql-service-name postgres:postgres-service-name.
- DD_TRACE_PARTIAL_FLUSH_ENABLED
- Default: false
 Enables incrementally flushing large traces to the Datadog Agent, reducing the chance of rejection by the Agent. Use only when you have long-lived traces or traces with many spans. Valid values aretrueorfalse.
Added in version 1.54.0. Only compatible with the Datadog Agent 7.26.0+.
- DD_TRACE_PARTIAL_FLUSH_MIN_SPANS
- Default: 1000
 Number of spans within a trace that can be partially flushed to the Datadog Agent.DD_TRACE_PARTIAL_FLUSH_ENABLEDmust betruefor partial flushing to occur.
Added in version 1.54.0. Only compatible with the Datadog Agent 7.26.0+.
- DD_TRACE_CLIENT_IP_ENABLED
- Default: false
 Enable client IP collection from relevant IP headers in HTTP request spans.
Added in version 1.47.0
- DD_TRACE_HEADER_TAGS
- Default: null
 List of comma-separated HTTP headers to be used as span tags. Optionally specify a “mapped” field to rename the request header as a tag. Configuration can be set globally with this environment variable, or at the integration level using the options specified in the Go documentation. This feature is compatible with HTTP1 headers.
 Examples:
 - Capture request header my-header:"DD_TRACE_HEADER_TAGS=my-header"
- Capture request headers my-header-1andmy-header-2:"DD_TRACE_HEADER_TAGS=my-header1,my-header-2"
- Capture request header my-headerand rename it tomy-tag:"DD_TRACE_HEADER_TAGS=my-header:my-tag"
 
- DD_TAGS
- Default: none
 A list of default tags to be added to every span, metric, and profile. Tags can be separated by commas or spaces, for example:layer:api,team:intake,key:valueorlayer:api team:intake key:value. Key-value pairs must be of string-convertible types.
Agent
- DD_AGENT_HOST
- Default: localhost
 Override the default trace Agent host address for trace submission. Ignored ifDD_TRACE_AGENT_URLis set.
- DD_DOGSTATSD_PORT
- Default: 8125
 Overrides the default trace Agent port for DogStatsD metric submission. If the Agent configuration setsdogstatsd_portorDD_DOGSTATSD_PORTto something other than the default8125, then the library configurationDD_DOGSTATSD_PORTmust match it.
- DD_INSTRUMENTATION_TELEMETRY_ENABLED
- Default: true
 Datadog may collect environmental and diagnostic information about your system to improve the product. When false, this telemetry data will not be collected.
Runtime metrics
- DD_RUNTIME_METRICS_ENABLED
- Default: false
 Enable runtime metric collection.
Added in version 1.26.0.
Trace context propagation
- DD_TRACE_PROPAGATION_STYLE
- Default: datadog,tracecontext,baggage
 Configures trace header injection and extraction style. See Propagating Go Trace Context for more information.
The APM environment name may be configured in the Agent or using the WithEnv start option of the tracer.
Further reading