HTTP configuration options
editHTTP configuration options
editCaptureBody
(performance) (
[1.0.1]
Added in 1.0.1.
)
editFor transactions that are HTTP requests, the agent can optionally capture the request body, e.g., POST variables. If the request has a body and this setting is disabled, the body will be shown as [REDACTED]. This option is case-insensitive.
To allow capturing request bodies, the agent sets AllowSynchronousIO
to true
on a per
request basis in ASP.NET Core, since capturing can occur in synchronous code paths.
With ASP.NET Core 3.0 onwards, AllowSynchronousIO
is false
by default
because a large number of blocking synchronous I/O operations can lead to thread pool starvation,
which makes the application unresponsive. If your application becomes unresponsive with this
feature enabled, consider disabling capturing.
In ASP.NET (.NET Full Framework), this setting has no effect on non-buffered requests (see HttpRequest.ReadEntityBodyMode).
Request bodies often contain sensitive values like passwords and credit card numbers. If your service handles data like this, we advise to only enable this feature with care. Turning on body capturing can also significantly increase the overhead in terms of heap usage, network utilization, and Elasticsearch index size.
Possible options are off
, errors
, transactions
and all
:
-
off
- request bodies will never be reported -
errors
- request bodies will only be reported with errors -
transactions
- request bodies will only be reported with request transactions -
all
- request bodies will be reported with both errors and request transactions
This setting can be changed after the agent starts.
Environment variable name | IConfiguration or Web.config key |
---|---|
|
|
Default | Type |
---|---|
|
String |
CaptureBodyContentTypes
(performance) (
[1.0.1]
Added in 1.0.1.
)
editConfigures the content types to be captured.
This option supports the wildcard *
, which matches zero or more characters.
Examples: /foo/*/bar/*/baz*
, *foo*
.
Matching is case insensitive.
This setting can be changed after the agent starts.
Environment variable name | IConfiguration or Web.config key |
---|---|
|
|
Default | Type |
---|---|
|
Comma separated string |
CaptureHeaders
(performance)
editIf set to true
,
the agent will capture request and response headers, including cookies.
Setting this to false
reduces memory allocations, network bandwidth, and disk space used by Elasticsearch.
Environment variable name | IConfiguration or Web.config key |
---|---|
|
|
Default | Type |
---|---|
|
Boolean |
TraceContinuationStrategy
(performance) (
[1.17.0]
Added in 1.17.0.
)
editValid options: continue
, restart
, restart_external
.
Environment variable name | IConfiguration or Web.config key |
---|---|
|
|
Default | Type |
---|---|
|
String |
The traceparent
header of requests that are traced by the Elastic APM .NET Agent might have been added by a 3rd party component.
This situation becomes more and more common as the w3c trace context gets adopted. In such cases you may end up with traces where part of the trace is outside of Elastic APM.
In order to handle this properly, the agent offers trace continuation strategies with the following values and behavior:
-
continue
: The agent takes thetraceparent
header as it is and applies it to the new transaction. -
restart
: The agent always creates a new trace with a new trace id. In this case the agent creates a span link in the new transaction pointing to the originaltraceparent
. -
restart_external
: The agent first checks thetracestate
header. If the header contains thees
vendor flag (which means the request is coming from a service monitored by an Elastic APM Agent), it’s treated as internal, otherwise (including the case when thetracestate
header is not present) it’s treated as external. In case of external calls the agent creates a new trace with a new trace id and creates a link in the new transaction pointing to the original trace.
TransactionIgnoreurls
(performance)
editThis is used to restrict requests to certain urls from being instrumented.
This property should be set to a comma separated string containing one or more paths.
For example, in order to ignore the urls /foo
and /bar
, set the configuration value to "/foo,/bar"
.
When an incoming HTTP request is detected, its request path will be tested against each element in this list.
For example, adding /home/index
to this list would match and remove instrumentation from the following urls:
https://www.mycoolsite.com/home/index http://localhost/home/index http://whatever.com/home/index?value1=123
In other words, the matching always happens based on the request path—hosts and query strings are ignored.
This option supports the wildcard *
, which matches zero or more characters.
Examples: "/foo/*/bar/*/baz*
, *foo*"
.
Matching is case insensitive by default.
Prepending an element with (?-i)
makes the matching case sensitive.
All errors that are captured during a request to an ignored url are still sent to the APM Server regardless of this setting.
Environment variable name | IConfiguration or Web.config key |
---|---|
|
|
Default | Type |
---|---|
|
Comma separated string |
Changing this configuration will overwrite the default value.
TransactionNameGroups
(
[1.27.0]
Added in 1.27.0.
)
editWith this option, you can group transaction names that contain dynamic parts with a wildcard expression. For example, the pattern GET /user/*/cart
would consolidate transactions, such as GET /users/42/cart
and GET /users/73/cart
into a single transaction name GET /users/*/cart
, hence reducing the transaction name cardinality.
This option supports the wildcard *
, which matches zero or more characters. Examples: GET /foo/*/bar/*/baz*`
, *foo*
. Matching is case insensitive by default. Prepending an element with (?-i) makes the matching case sensitive.
Environment variable name | IConfiguration or Web.config key |
---|---|
|
|
Default | Type |
---|---|
|
String |
UseElasticTraceparentHeader
(
[1.3.0]
Added in 1.3.0.
)
editTo enable distributed tracing, the agent adds trace context headers to outgoing HTTP requests made with the HttpClient
type. These headers (traceparent
and tracestate
) are defined in the W3C Trace Context specification.
When this setting is true
, the agent also adds the header elasticapm-traceparent
for backwards compatibility with older versions of Elastic APM agents. Versions prior to 1.3.0
only read the elasticapm-traceparent
header.
Environment variable name | IConfiguration or Web.config key |
---|---|
|
|
Default | Type |
---|---|
|
Boolean |
UsePathAsTransactionName
(
[1.27.0]
Added in 1.27.0.
)
editIf set to true
, transaction names of unsupported or partially-supported frameworks will be in the form of $method $path
instead of just $method unknown route
.
If your urls contain path parameters like /user/$userId
,
you should be very careful when enabling this flag,
as it can lead to an explosion of transaction groups.
Take a look at the TransactionNameGroups
option on how to mitigate this problem by grouping urls together.
Environment variable name | IConfiguration or Web.config key |
---|---|
|
|
Default | Type |
---|---|
|
Boolean |
UseWindowsCredentials
editSet this property to true when requests made by the APM agent should, if requested by the server, be authenticated using the credentials of the currently logged on user.
This is useful when using windows authentication on a proxy, that routes APM agent requests to the APM server.
Environment variable name | IConfiguration or Web.config key |
---|---|
|
|
Default | Type |
---|---|
|
Boolean |
BaggageToAttach
(
[1.24]
Added in 1.24.
)
editControls which baggage values are automatically attached to the given event (transaction, span, error). Baggage values are derived from the baggage
header defined in the W3C Baggage specification. You can programmatically write and read baggage values via the Activity API. For more details, see our documentation on how to integrate with OpenTelemetry
.
Environment variable name | IConfiguration key |
---|---|
|
|
Default | Type |
---|---|
|
Comma separated string |
TraceContextIgnoreSampledFalse
editUse of TraceContextIgnoreSampledFalse
is deprecated. Use TraceContinuationStrategy
with the restart_external
value.
The agent uses the W3C Trace Context specification and standards for distributed tracing. The traceparent header from the W3C Trace Context specification defines a sampled flag which is propagated from a caller service to a callee service, and determines whether a trace is sampled in the callee service. The default behavior of the agent honors the sampled flag value and behaves accordingly.
There may be cases where you wish to change the default behavior of the agent with respect to the sampled flag. By setting the TraceContextIgnoreSampled
configuration value to true
, the agent ignores the sampled flag of the W3C Trace Context traceparent header when it has a value of false
and and there is no agent specific tracestate header value present. In ignoring the sampled flag, the agent makes a sampling decision based on the sample rate. This can be useful when a caller service always sets a sampled flag value of false
, that results in the agent never sampling any transactions.
.NET 5 applications set the W3C Trace Context for outgoing HTTP requests by default, but with the traceparent header sampled flag set to false
. If a .NET 5 application has an active agent, the agent ensures that the sampled flag is propagated with the agent’s sampling decision. If a .NET 5 application does not have an active agent however, and the application calls another service that does have an active agent, the propagation of a sampled flag value of false
results in no sampled transactions in the callee service.
If your application is called by an .NET 5 application that does not have an active agent, setting the TraceContextIgnoreSampledFalse
configuration value to true
instructs the agent to start a new transaction and make a sampling decision based on the sample rate, when the traceparent header sampled flag has a value of false
and there is no agent specific tracestate header value present.
Environment variable name | IConfiguration or Web.config key |
---|---|
|
|
Default | Type |
---|---|
|
Boolean |