Documentation ¶
Index ¶
- Constants
- Variables
- type AgentConfig
- type CreditCardsConfig
- type DebuggerProxyConfig
- type EVPProxy
- type Enablable
- type Endpoint
- type FargateOrchestratorName
- type InstallSignatureConfig
- type OTLP
- type ObfuscationConfig
- type ProfilingProxyConfig
- type RemoteClient
- type ReplaceRule
- type ResetClient
- type SymDBProxyConfig
- type Tag
- type TagRegex
- type TelemetryConfig
- type WriterConfig
Constants ¶
const ServiceName = "datadog-trace-agent"
ServiceName specifies the service name used in the operating system.
const TelemetryEndpointPrefix = "https://instrumentation-telemetry-intake."
TelemetryEndpointPrefix specifies the prefix of the telemetry endpoint URL.
Variables ¶
var ErrContainerTagsFuncNotDefined = errors.New("containerTags function not defined")
ErrContainerTagsFuncNotDefined is returned when the containerTags function is not defined.
var ErrMissingAPIKey = errors.New("you must specify an API Key, either via a configuration file or the DD_API_KEY env var")
ErrMissingAPIKey is returned when the config could not be validated due to missing API key.
Functions ¶
This section is empty.
Types ¶
type AgentConfig ¶
type AgentConfig struct { Features map[string]struct{} Enabled bool AgentVersion string GitCommit string Site string // the intake site to use (e.g. "datadoghq.com") // FargateOrchestrator specifies the name of the Fargate orchestrator. e.g. "ECS", "EKS", "Unknown" FargateOrchestrator FargateOrchestratorName // Global Hostname string DefaultEnv string // the traces will default to this environment ConfigPath string // the source of this config, if any // Endpoints specifies the set of hosts and API keys where traces and stats // will be uploaded to. The first endpoint is the main configuration endpoint; // any following ones are read from the 'additional_endpoints' parts of the // configuration file, if present. Endpoints []*Endpoint // Concentrator BucketInterval time.Duration // the size of our pre-aggregation per bucket ExtraAggregators []string // DEPRECATED PeerServiceAggregation bool // TO BE DEPRECATED - enables/disables stats aggregation for peer.service, used by Concentrator and ClientStatsAggregator PeerTagsAggregation bool // enables/disables stats aggregation for peer entity tags, used by Concentrator and ClientStatsAggregator ComputeStatsBySpanKind bool // enables/disables the computing of stats based on a span's `span.kind` field PeerTags []string // additional tags to use for peer entity stats aggregation // Sampler configuration ExtraSampleRate float64 TargetTPS float64 ErrorTPS float64 MaxEPS float64 MaxRemoteTPS float64 // Rare Sampler configuration RareSamplerEnabled bool RareSamplerTPS int RareSamplerCooldownPeriod time.Duration RareSamplerCardinality int // Receiver ReceiverHost string ReceiverPort int ReceiverSocket string // if not empty, UDS will be enabled on unix://<receiver_socket> ConnectionLimit int // for rate-limiting, how many unique connections to allow in a lease period (30s) ReceiverTimeout int MaxRequestBytes int64 // specifies the maximum allowed request size for incoming trace payloads TraceBuffer int // specifies the number of traces to buffer before blocking. Decoders int // specifies the number of traces that can be concurrently decoded. MaxConnections int // specifies the maximum number of concurrent incoming connections allowed. DecoderTimeout int // specifies the maximum time in milliseconds that the decoders will wait for a turn to accept a payload before returning 429 WindowsPipeName string PipeBufferSize int PipeSecurityDescriptor string GUIPort string // the port of the Datadog Agent GUI (for control access) // Writers SynchronousFlushing bool // Mode where traces are only submitted when FlushAsync is called, used for Serverless Extension StatsWriter *WriterConfig TraceWriter *WriterConfig ConnectionResetInterval time.Duration // frequency at which outgoing connections are reset. 0 means no reset is performed // MaxSenderRetries is the maximum number of retries that a sender will perform // before giving up. Note that the sender may not perform all MaxSenderRetries if // the agent is under load and the outgoing payload queue is full. In that // case, the sender will drop failed payloads when it is unable to enqueue // them for another retry. MaxSenderRetries int // internal telemetry StatsdEnabled bool StatsdHost string StatsdPort int StatsdPipeName string // for Windows Pipes StatsdSocket string // for UDS Sockets // logging LogFilePath string LogThrottling bool // watchdog MaxMemory float64 // MaxMemory is the threshold (bytes allocated) above which program panics and exits, to be restarted MaxCPU float64 // MaxCPU is the max UserAvg CPU the program should consume WatchdogInterval time.Duration // WatchdogInterval is the delay between 2 watchdog checks // http/s proxying ProxyURL *url.URL SkipSSLValidation bool // filtering Ignore map[string][]string // ReplaceTags is used to filter out sensitive information from tag values. // It maps tag keys to a set of replacements. Only supported in A6. ReplaceTags []*ReplaceRule // GlobalTags list metadata that will be added to all spans GlobalTags map[string]string // transaction analytics AnalyzedRateByServiceLegacy map[string]float64 AnalyzedSpansByService map[string]map[string]float64 // infrastructure agent binary DDAgentBin string // Obfuscation holds sensitive data obufscator's configuration. Obfuscation *ObfuscationConfig // MaxResourceLen the maximum length the resource can have MaxResourceLen int // RequireTags specifies a list of tags which must be present on the root span in order for a trace to be accepted. RequireTags []*Tag // RejectTags specifies a list of tags which must be absent on the root span in order for a trace to be accepted. RejectTags []*Tag // RequireTagsRegex specifies a list of regexp for tags which must be present on the root span in order for a trace to be accepted. RequireTagsRegex []*TagRegex // RejectTagsRegex specifies a list of regexp for tags which must be absent on the root span in order for a trace to be accepted. RejectTagsRegex []*TagRegex // OTLPReceiver holds the configuration for OpenTelemetry receiver. OTLPReceiver *OTLP // ProfilingProxy specifies settings for the profiling proxy. ProfilingProxy ProfilingProxyConfig // Telemetry settings TelemetryConfig *TelemetryConfig // EVPProxy contains the settings for the EVPProxy proxy. EVPProxy EVPProxy // DebuggerProxy contains the settings for the Live Debugger proxy. DebuggerProxy DebuggerProxyConfig // DebuggerDiagnosticsProxy contains the settings for the Live Debugger diagnostics proxy. DebuggerDiagnosticsProxy DebuggerProxyConfig // SymDBProxy contains the settings for the Symbol Database proxy. SymDBProxy SymDBProxyConfig // Proxy specifies a function to return a proxy for a given Request. // See (net/http.Transport).Proxy for more details. Proxy func(*http.Request) (*url.URL, error) `json:"-"` // MaxCatalogEntries specifies the maximum number of services to be added to the priority sampler's // catalog. If not set (0) it will default to 5000. MaxCatalogEntries int // RemoteConfigClient retrieves sampling updates from the remote config backend RemoteConfigClient RemoteClient `json:"-"` // ContainerTags ... ContainerTags func(cid string) ([]string, error) `json:"-"` // ContainerProcRoot is the root dir for `proc` info ContainerProcRoot string // DebugServerPort defines the port used by the debug server DebugServerPort int // Install Signature InstallSignature InstallSignatureConfig // Lambda function name LambdaFunctionName string }
AgentConfig handles the interpretation of the configuration (with default behaviors) in one place. It is also a simple structure to share across all the Agent components, with 100% safe and reliable values. It is exposed with expvar, so make sure to exclude any sensible field from JSON encoding. Use New() to create an instance.
func (*AgentConfig) APIKey ¶
func (c *AgentConfig) APIKey() string
APIKey returns the first (main) endpoint's API key.
func (*AgentConfig) AllFeatures ¶ added in v0.44.0
func (c *AgentConfig) AllFeatures() []string
func (*AgentConfig) HasFeature ¶ added in v0.44.0
func (c *AgentConfig) HasFeature(feat string) bool
func (*AgentConfig) NewHTTPClient ¶
func (c *AgentConfig) NewHTTPClient() *ResetClient
NewHTTPClient returns a new http.Client to be used for outgoing connections to the Datadog API.
func (*AgentConfig) NewHTTPTransport ¶
func (c *AgentConfig) NewHTTPTransport() *http.Transport
NewHTTPTransport returns a new http.Transport to be used for outgoing connections to the Datadog API.
type CreditCardsConfig ¶
type CreditCardsConfig struct { // Enabled specifies whether this feature should be enabled. Enabled bool `mapstructure:"enabled"` // Luhn specifies whether Luhn checksum validation should be enabled. // https://dev.to/shiraazm/goluhn-a-simple-library-for-generating-calculating-and-verifying-luhn-numbers-588j // It reduces false positives, but increases the CPU time X3. Luhn bool `mapstructure:"luhn"` }
CreditCardsConfig holds the configuration for credit card obfuscation in (Meta) tags.
type DebuggerProxyConfig ¶
type DebuggerProxyConfig struct { // DDURL ... DDURL string // APIKey ... APIKey string `json:"-"` // Never marshal this field // AdditionalEndpoints is a map of additional Datadog sites to API keys. AdditionalEndpoints map[string][]string `json:"-"` // Never marshal this field }
DebuggerProxyConfig ...
type EVPProxy ¶ added in v0.38.0
type EVPProxy struct { // Enabled reports whether EVPProxy is enabled (true by default). Enabled bool // DDURL is the Datadog site to forward payloads to (defaults to the Site setting if not set). DDURL string // APIKey is the main API Key (defaults to the main API key). APIKey string `json:"-"` // Never marshal this field // ApplicationKey to be used for requests with the X-Datadog-NeedsAppKey set (defaults to the top-level Application Key). ApplicationKey string `json:"-"` // Never marshal this field // AdditionalEndpoints is a map of additional Datadog sites to API keys. AdditionalEndpoints map[string][]string // MaxPayloadSize indicates the size at which payloads will be rejected, in bytes. MaxPayloadSize int64 }
EVPProxy contains the settings for the EVPProxy proxy.
type Enablable ¶
type Enablable struct {
Enabled bool `mapstructure:"enabled"`
}
Enablable can represent any option that has an "enabled" boolean sub-field.
type Endpoint ¶
type Endpoint struct { APIKey string `json:"-"` // never marshal this Host string // NoProxy will be set to true when the proxy setting for the trace API endpoint // needs to be ignored (e.g. it is part of the "no_proxy" list in the yaml settings). NoProxy bool }
Endpoint specifies an endpoint that the trace agent will write data (traces, stats & services) to.
type FargateOrchestratorName ¶
type FargateOrchestratorName string
FargateOrchestratorName is a Fargate orchestrator name.
const ( // OrchestratorECS represents AWS ECS OrchestratorECS FargateOrchestratorName = "ECS" // OrchestratorEKS represents AWS EKS OrchestratorEKS FargateOrchestratorName = "EKS" // OrchestratorUnknown is used when we cannot retrieve the orchestrator OrchestratorUnknown FargateOrchestratorName = "Unknown" )
type InstallSignatureConfig ¶ added in v0.50.0
type InstallSignatureConfig struct { Found bool `json:"-"` InstallID string `json:"install_id"` InstallType string `json:"install_type"` InstallTime int64 `json:"install_time"` }
InstallSignatureConfig contains the information on how the agent was installed and a unique identifier that distinguishes this agent from others.
type OTLP ¶
type OTLP struct { // BindHost specifies the host to bind the receiver to. BindHost string `mapstructure:"-"` // GRPCPort specifies the port to use for the plain HTTP receiver. // If unset (or 0), the receiver will be off. GRPCPort int `mapstructure:"grpc_port"` // SpanNameRemappings is the map of datadog span names and preferred name to map to. This can be used to // automatically map Datadog Span Operation Names to an updated value. All entries should be key/value pairs. SpanNameRemappings map[string]string `mapstructure:"span_name_remappings"` // SpanNameAsResourceName specifies whether the OpenTelemetry span's name should be // used as the Datadog span's operation name. By default (when this is false), the // operation name is deduced from a combination between the instrumentation scope // name and the span kind. // // For context, the OpenTelemetry 'Span Name' is equivalent to the Datadog 'resource name'. // The Datadog Span's Operation Name equivalent in OpenTelemetry does not exist, but the span's // kind comes close. SpanNameAsResourceName bool `mapstructure:"span_name_as_resource_name"` // MaxRequestBytes specifies the maximum number of bytes that will be read // from an incoming HTTP request. MaxRequestBytes int64 `mapstructure:"-"` // ProbabilisticSampling specifies the percentage of traces to ingest. Exceptions are made for errors // and rare traces (outliers) if "RareSamplerEnabled" is true. Invalid values are equivalent to 100. // If spans have the "sampling.priority" attribute set, probabilistic sampling is skipped and the user's // decision is followed. ProbabilisticSampling float64 // AttributesTranslator specifies an OTLP to Datadog attributes translator. AttributesTranslator *attributes.Translator `mapstructure:"-"` }
OTLP holds the configuration for the OpenTelemetry receiver.
type ObfuscationConfig ¶
type ObfuscationConfig struct { // ES holds the obfuscation configuration for ElasticSearch bodies. ES obfuscate.JSONConfig `mapstructure:"elasticsearch"` // Mongo holds the obfuscation configuration for MongoDB queries. Mongo obfuscate.JSONConfig `mapstructure:"mongodb"` // SQLExecPlan holds the obfuscation configuration for SQL Exec Plans. This is strictly for safety related obfuscation, // not normalization. Normalization of exec plans is configured in SQLExecPlanNormalize. SQLExecPlan obfuscate.JSONConfig `mapstructure:"sql_exec_plan"` // SQLExecPlanNormalize holds the normalization configuration for SQL Exec Plans. SQLExecPlanNormalize obfuscate.JSONConfig `mapstructure:"sql_exec_plan_normalize"` // HTTP holds the obfuscation settings for HTTP URLs. HTTP obfuscate.HTTPConfig `mapstructure:"http"` // RemoveStackTraces specifies whether stack traces should be removed. // More specifically "error.stack" tag values will be cleared. RemoveStackTraces bool `mapstructure:"remove_stack_traces"` // Redis holds the configuration for obfuscating the "redis.raw_command" tag // for spans of type "redis". Redis obfuscate.RedisConfig `mapstructure:"redis"` // Memcached holds the configuration for obfuscating the "memcached.command" tag // for spans of type "memcached". Memcached obfuscate.MemcachedConfig `mapstructure:"memcached"` // CreditCards holds the configuration for obfuscating credit cards. CreditCards CreditCardsConfig `mapstructure:"credit_cards"` }
ObfuscationConfig holds the configuration for obfuscating sensitive data for various span types.
func (*ObfuscationConfig) Export ¶
func (o *ObfuscationConfig) Export(conf *AgentConfig) obfuscate.Config
Export returns an obfuscate.Config matching o.
type ProfilingProxyConfig ¶
type ProfilingProxyConfig struct { // DDURL ... DDURL string // AdditionalEndpoints ... AdditionalEndpoints map[string][]string }
ProfilingProxyConfig ...
type RemoteClient ¶
type RemoteClient interface { Close() Start() Subscribe(string, func(update map[string]state.RawConfig, applyStateCallback func(string, state.ApplyStatus))) UpdateApplyStatus(cfgPath string, status state.ApplyStatus) }
RemoteClient client is used to APM Sampling Updates from a remote source. This is an interface around the client provided by pkg/config/remote to allow for easier testing.
type ReplaceRule ¶
type ReplaceRule struct { // Name specifies the name of the tag that the replace rule addresses. However, // some exceptions apply such as: // • "resource.name" will target the resource // • "*" will target all tags and the resource Name string `mapstructure:"name"` // Pattern specifies the regexp pattern to be used when replacing. It must compile. Pattern string `mapstructure:"pattern"` // Re holds the compiled Pattern and is only used internally. Re *regexp.Regexp `mapstructure:"-"` // Repl specifies the replacement string to be used when Pattern matches. Repl string `mapstructure:"repl"` }
ReplaceRule specifies a replace rule.
type ResetClient ¶
type ResetClient struct {
// contains filtered or unexported fields
}
ResetClient wraps (http.Client).Do and resets the underlying connections at the configured interval
func NewResetClient ¶
func NewResetClient(resetInterval time.Duration, httpClientFactory func() *http.Client) *ResetClient
NewResetClient returns an initialized Client resetting connections at the passed resetInterval ("0" means that no reset is performed). The underlying http.Client used will be created using the passed http client factory.
type SymDBProxyConfig ¶ added in v0.45.0
type SymDBProxyConfig struct { // DDURL ... DDURL string // APIKey ... APIKey string `json:"-"` // Never marshal this field // AdditionalEndpoints is a map of additional Datadog endpoints to API keys. AdditionalEndpoints map[string][]string `json:"-"` // Never marshal this field }
SymDBProxyConfig ...
type TelemetryConfig ¶
TelemetryConfig holds Instrumentation telemetry Endpoints information
type WriterConfig ¶
type WriterConfig struct { // ConnectionLimit specifies the maximum number of concurrent outgoing // connections allowed for the sender. ConnectionLimit int `mapstructure:"connection_limit"` // QueueSize specifies the maximum number or payloads allowed to be queued // in the sender. QueueSize int `mapstructure:"queue_size"` // FlushPeriodSeconds specifies the frequency at which the writer's buffer // will be flushed to the sender, in seconds. Fractions are permitted. FlushPeriodSeconds float64 `mapstructure:"flush_period_seconds"` }
WriterConfig specifies configuration for an API writer.