Datadog.Trace.Bundle
3.6.1
Prefix Reserved
dotnet add package Datadog.Trace.Bundle --version 3.6.1
NuGet\Install-Package Datadog.Trace.Bundle -Version 3.6.1
<PackageReference Include="Datadog.Trace.Bundle" Version="3.6.1" />
paket add Datadog.Trace.Bundle --version 3.6.1
#r "nuget: Datadog.Trace.Bundle, 3.6.1"
// Install Datadog.Trace.Bundle as a Cake Addin #addin nuget:?package=Datadog.Trace.Bundle&version=3.6.1 // Install Datadog.Trace.Bundle as a Cake Tool #tool nuget:?package=Datadog.Trace.Bundle&version=3.6.1
Datadog.Trace.Bundle
NuGet package
This package contains the full Datadog .NET APM suite for Tracing (automatic, and custom), Continuous Profiler and Application Security Monitoring (ASM).
Should I install this package?
Do not install this package if any of the following are true:
- You have already installed the Datadog .NET Tracer MSI on Windows. Install Datadog.Trace instead if you need custom instrumentation.
- You have already installed the Datadog .NET package on Linux. Install Datadog.Trace instead if you need custom instrumentation.
- You instrument your application using the .NET dd-trace tool. Install Datadog.Trace instead if you need custom instrumentation.
- Your application is running in Azure App Services. Install the AAS extension instead.
- Your application is running in IIS on Windows. This package is not supported; install the MSI instead, and install Datadog.Trace if you also need custom instrumentation.
Install this package if:
- You are running in a scenario where you can't install an MSI or Linux package. Services such as Azure Service Fabric provide limited access to the underlying server.
- You want to use both custom and automatic instrumentation, and keeping tracer versions in-sync is a chore.
- You are running multiple applications on a server and some of them use custom instrumentation, as well as automatic instrumentation.
- You prefer to deploy a static set of binaries rather than relying on existing infrastructure on the host.
If you are using automatic instrumentation and would like to interact with APM only through C# attributes, see the Datadog.Trace.Annotations NuGet package.
What does Datadog.Trace.Bundle contain?
Datadog.Trace.Bundle contains two things:
- A reference to the Datadog.Trace NuGet package for custom instrumentation.
- The native binaries required for automatic instrumentation, for the Continuous Profiler, and for ASM.
These native binaries are identical to those installed by the MSI and Linux installer packages, so Datadog.Trace.Bundle should be considered an alternative deployment mechanism for automatic instrumentation.
The main advantages of Datadog.Trace.Bundle over the MSI or Linux packages are:
- You can use it in locations where you cannot access the underlying host to install the MSI or Linux package.
- You can have multiple applications on the same host using different versions of Datadog.Trace.Bundle without issue.
Getting Started
- Configure the Datadog agent for APM as described in our documentation.
- Add the Datadog.Trace.Bundle NuGet package to your project, using
dotnet add package Datadog.Trace.Bundle
, for example. - Configure the tracer on the server, as described below
- View your live data on Datadog.
Configure the tracer
After adding the NuGet package to your project, set the following required environment variables to enable automatic instrumentation of your application and restart the application.
NOTE: The following are the mandatory variables. For further configuration options, see our public documentation for the Tracer and the Continuous Profiler.
.NET Core:
CORECLR_ENABLE_PROFILING=1
CORECLR_PROFILER={846F5F1C-F9AE-4B07-969E-05C26BC060D8}
CORECLR_PROFILER_PATH=<System-dependent path>
DD_DOTNET_TRACER_HOME=<APP_DIRECTORY>/datadog
.NET Framework:
COR_ENABLE_PROFILING=1
COR_PROFILER={846F5F1C-F9AE-4B07-969E-05C26BC060D8}
COR_PROFILER_PATH=<System-dependent path>
DD_DOTNET_TRACER_HOME=<APP_DIRECTORY>/datadog
The value for the <APP_DIRECTORY>
placeholder is the path to the directory containing the application’s .dll files. The value for the CORECLR_PROFILER_PATH
/COR_PROFILER_PATH
environment variable varies based on the system where the application is running:
OPERATING SYSTEM AND PROCESS ARCHITECTURE | CORECLR_PROFILER_PATH VALUE |
---|---|
Alpine Linux x64 | <APP_DIRECTORY>/datadog/linux-musl-x64/Datadog.Trace.ClrProfiler.Native.so |
Linux x64 | <APP_DIRECTORY>/datadog/linux-x64/Datadog.Trace.ClrProfiler.Native.so |
Alpine Linux ARM64 | <APP_DIRECTORY>/datadog/linux-musl-arm64/Datadog.Trace.ClrProfiler.Native.so |
Linux ARM64 | <APP_DIRECTORY>/datadog/linux-arm64/Datadog.Trace.ClrProfiler.Native.so |
Windows x64 | <APP_DIRECTORY>\datadog\win-x64\Datadog.Trace.ClrProfiler.Native.dll |
Windows x86 | <APP_DIRECTORY>\datadog\win-x86\Datadog.Trace.ClrProfiler.Native.dll |
For Docker images running on Linux, configure the image to run the createLogPath.sh script:
RUN /<APP_DIRECTORY>/datadog/createLogPath.sh
Examples
Docker examples are available here
Get in touch
If you have questions, feedback, or feature requests, reach our support.
Learn more about Target Frameworks and .NET Standard.
-
.NETCoreApp 3.1
- Datadog.Trace (>= 3.6.1)
-
.NETFramework 4.6.1
- Datadog.Trace (>= 3.6.1)
-
.NETStandard 2.0
- Datadog.Trace (>= 3.6.1)
-
net6.0
- Datadog.Trace (>= 3.6.1)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Datadog.Trace.Bundle:
Package | Downloads |
---|---|
CleanWaterServices.LoggingTelemetry
A extension library atop of Serilog Library. It creates a clean wrapper for logging and telemetry into the environment insight platform. |
GitHub repositories (1)
Showing the top 1 popular GitHub repositories that depend on Datadog.Trace.Bundle:
Repository | Stars |
---|---|
DataDog/dd-trace-dotnet
.NET Client Library for Datadog APM
|
Version | Downloads | Last updated |
---|---|---|
3.6.1 | 5,216 | 11/26/2024 |
3.6.0 | 16,692 | 11/19/2024 |
3.5.0 | 37,667 | 11/6/2024 |
3.4.1 | 30,222 | 10/28/2024 |
3.4.0 | 20,202 | 10/24/2024 |
3.3.1 | 159,665 | 9/18/2024 |
3.3.0 | 8,672 | 9/16/2024 |
3.2.0 | 71,629 | 9/2/2024 |
3.1.0-prerelease | 1,051 | 8/14/2024 |
3.0.0-prerelease | 874 | 7/29/2024 |
2.61.0 | 4,723 | 11/6/2024 |
2.60.0 | 5,677 | 10/24/2024 |
2.59.0 | 80,910 | 9/16/2024 |
2.58.0 | 22,833 | 9/2/2024 |
2.57.0 | 111,847 | 8/14/2024 |
2.56.0 | 122,886 | 7/25/2024 |
2.55.0 | 34,811 | 7/18/2024 |
2.54.0 | 76,384 | 7/9/2024 |
2.53.2 | 1,304,237 | 6/19/2024 |
2.53.1 | 23,116 | 6/17/2024 |
2.53.0 | 69,508 | 6/11/2024 |
2.52.0 | 190,067 | 5/23/2024 |
2.51.0 | 228,407 | 5/6/2024 |
2.50.0 | 136,587 | 4/17/2024 |
2.49.0 | 369,758 | 3/18/2024 |
2.48.0 | 711,801 | 2/29/2024 |
2.47.0 | 197,937 | 2/14/2024 |
2.46.0 | 284,395 | 1/24/2024 |
2.45.0 | 116,533 | 1/10/2024 |
2.44.0 | 224,173 | 12/19/2023 |
2.43.0 | 128,686 | 12/5/2023 |
2.42.0 | 5,035 | 11/21/2023 |
2.41.0 | 243,361 | 11/6/2023 |
2.40.0 | 138,691 | 10/16/2023 |
2.39.0 | 27,881 | 10/11/2023 |
2.38.0 | 140,684 | 9/20/2023 |
2.37.0 | 161,469 | 8/31/2023 |
2.36.0 | 248,028 | 8/23/2023 |
2.35.0 | 158,678 | 7/31/2023 |
2.34.0 | 34,299 | 7/25/2023 |
2.33.0 | 128,262 | 7/4/2023 |
2.32.0 | 146,121 | 6/20/2023 |
2.31.0 | 131,857 | 5/31/2023 |
2.30.0 | 293,423 | 5/5/2023 |
2.29.0 | 172,950 | 4/17/2023 |
2.28.0 | 25,777 | 4/12/2023 |
2.27.0 | 98,995 | 3/24/2023 |
2.26.0 | 131,836 | 3/9/2023 |
2.24.1 | 651,571 | 2/27/2023 |
2.24.0 | 10,681 | 2/24/2023 |
2.23.0 | 278,326 | 2/8/2023 |
2.22.0 | 95,609 | 1/24/2023 |
2.21.0 | 206,171 | 12/20/2022 |
2.20.0 | 92,865 | 12/2/2022 |
2.19.0 | 92,317 | 11/10/2022 |
2.18.0 | 150,784 | 10/25/2022 |
2.17.0 | 709,797 | 10/11/2022 |
2.16.0 | 40,211 | 10/7/2022 |
See release notes at https://github.com/DataDog/dd-trace-dotnet/releases.
Please note that Datadog does not support tracing (manual or automatic) in partial-trust environments.