Releases: DataDog/dd-trace-dotnet
2.24.1
DD_DBM_PROPAGATION_MODE
. The issue is resolved in version 2.35.0.
Enabling DD_DBM_PROPAGATION_MODE
may cause runtime errors in your application if you set the CommandType
property on DbCommand
to CommandType.StoredProcedure
. If you suspect your application or a dependent library is using stored procedures, and you are currently using this release, don't enable DD_DBM_PROPAGATION_MODE
until upgrading to 2.35.0+.
Summary
Hotfix to fix a potential performance issues on Windows, for .NET Framework apps.
Tracer
- Stop extracting SourceLink after 100 tries (#3837)
2.24.0
DD_DBM_PROPAGATION_MODE
. The issue is resolved in version 2.35.0.
Enabling DD_DBM_PROPAGATION_MODE
may cause runtime errors in your application if you set the CommandType
property on DbCommand
to CommandType.StoredProcedure
. If you suspect your application or a dependent library is using stored procedures, and you are currently using this release, don't enable DD_DBM_PROPAGATION_MODE
until upgrading to 2.35.0+.
Summary
%PROGRAMDATA%\Datadog .NET Tracer\logs
instead of %PROGRAMDTA%\Datadog-APM\logs\
.
Tracer
- Added support for publishing init containers that will be used for library injection in kubernetes. The feature isn't yet available though as it requires changes in the datadog agent as well, which will be released next month.
Profiler
- Reduce CPU consumption on Linux
- Improve performance of exceptions profiling
Changes
Tracer
- [Tracer] Fix
otel.status_code
/otel.library.name
from .NET Activity API (#3750) - [Tracer] add 128-bit
TraceId
struct (#3752) - [AAS] Bail out from starting processes if API_KEY isn't present (#3775)
- [Tracer] Fix
IDatadogLogger
analyzer warnings (#3785) - [Tracer] APM and DBM Link Injecting SQL Comment (#3784)
- [Tracer] Add support for Aerospike 6.0.0 (#3811)
CI Visibility
- [CI Visibility] - BenchmarkDotNet framework support (#3774)
- [CI Visibility] - Extract traits recursively in NUnit (#3777)
- [CI Visibility] - Small changes to the CI Visibility processors. (#3788)
- [CI Visibility] - Lazy initialise the ITR instance (#3789)
- [CI Visibility] - Defer await for git upload task (#3825)
ASM
- [ASM] Instrumented tests: basic setup (#3718)
- [ASM] Set span type to "vulnerability" for iast spans in console apps. (#3747)
- [ASM] Weak hashing instrumentation for net462 (#3776)
- [ASM] Add valueparts without source in vulnerability Json (#3810)
- [ASM] Weak cipher support for .net framework (#3818)
Continuous Profiler
- [Profiler] Add allocations recorder (#3753)
- [Profiler] Reduce memory allocation of the profiler (#3764)
- [Profiler] Validate exceptions sampling (#3767)
- [Profiler] Improve .NET exception profiler (#3770)
- [Profiler] Fix CppCheck version when installing (#3772)
- [Profiler] Fix flacky tests (#3778)
- Remove all references to
DD_DOTNET_PROFILER_HOME
(#3782) - [Profiler] Improve building thread stat file path (#3786)
- [Profiler] Improve Linux stackwalker deadlock detection (#3787)
- [Profiler] Take cores count into account for CPU profiling (#3793)
- [Profiler/CI] Remove profiler throughput tests from Github Actions (#3795)
- [Profiler] Add I/O-bound demo application (#3797)
- [Profiler] Add CI visibility on profiler AzDo jobs (#3799)
- [Profiler] Change scenario for better chances to get samples (#3801)
- [Profiler] Fix bug when retrieving number of cores (#3802)
- [Profiler] bug fixes (#3806)
- [Profiler] Increase leak size and fix exception (#3815)
- [Profiler] Add view for EndpointsCount controller (#3823)
Debugger
- [Dynamic Instrumentation] Support duration in debugger DSL (#3765)
- [Dynamic Instrumentation] Addressed a leakage by reusing probe data indices (#3771)
Miscellaneous
- Extract
git.commit.sha
andgit.repository_url
from SourceLink (#3652) - Change profiler and native loader default log dir (#3790)
- Small performance improvements (#3809)
Build / Test
- Add debugger team as CODEONWERS to missing directories (#3766)
- Generate container images for Kubernetes Admission Controller library injection (#3769)
- [Build] Add retries for build and package commands (#3780)
- Add analyzers for
IDatadogLogger
usages (#3781) - [Build/Test] Limit upload_container_images build stage to individual CI (#3783)
- [Build/Test] Publish official dd-lib-dotnet-init images on tagged commit (#3791)
- Fix test trigger on scheduled builds (#3792)
- [Build/Test] Add system tests for the library injection images (#3803)
- Fix MongoDb integration tests and bump to latest (#3808)
- Add test and sample project for .NET Activity API (#3597)
2.23.0
Summary
Tracer
- Resolve an issue introduced in 2.14.0 that could lead to the tracer not working after an upgrade of the tracer, if the server had been rebooted in between.
- Added support for Confluent.Kafka 2.x.
Changes
Tracer
- PRNG improvements for trace and span ids (#3651)
- Update
TagListGenerator
to use newForAttributeWithMetadataName
(#3662) - Add an enum extensions source generator (#3700)
- Add helper source generators for telemetry metrics (#3701)
- Add Analyzer for checking we don't use a public API (#3704)
- Add support for Confluent.Kafka 2.x.x (#3710)
- [Tracing] Converting to and from hex strings (#3715)
- Update log message with minimum datadog-agent version required for RCM (#3729)
- Handle multiple empty
tracestate
headers inW3CTraceContextPropagator
(#3745)
CI Visibility
- [CI Visibility] - Fix NUnit integration (#3696)
- [CI Visibility] Adds support for NUnit TearDown attributes (#3713)
- [CI Visibility] - CI specs updates (#3719)
- [CIVisibility] - Replace the datacollector logger error calls with warnings (#3723)
- [CI Visibility] - Add retries support for IOException in the coverage collector (#3726)
- [CI Visibility] - Ensure dd-trace uses same settings as target process (#3728)
- [CI Visibility] - Simpler CIVisibility initialization for the dd-trace runner (#3736)
- [CI Visibility] - Avoid sending the global code coverage tag if we have ITR enabled (#3740)
- [CI Visibility] - Improve test source start line for CI Visibility UI (#3755)
ASM
- [ASM] Call site instrumentation (#3453)
- [ASM] Added parent span Id to vulnerability json. (#3684)
- [ASM] SQL injection vulnerability detection (#3694)
- [ASM] User blocking (#3610)
- [ASM] SDK to track user events for Account Takeover and Business Logic abuse (#3703)
- [ASM] Update format of vulnerabilities Json. (#3705)
- [ASM] Fix waf library loader unit tests (#3706)
- [ASM] Fix rcm integration tests flakiness (#3714)
- [ASM] Fixed typo in function parameter (#3720)
- [ASM][GIT] Fine tuned code owners (#3721)
- [ASM] Aspects code generator tests (#3741)
- [ASM] upgrade WAF to 1.7.0 and WAF rules to 1.5.0 (#3742)
- [ASM] dispose context and nullchecks framework side (#3749)
- [ASM] Correct copy / paste error (#3760)
- [ASM] Removed unnecesary aspects file (#3711)
Continuous Profiler
- Move profiler CI from GitHub Actions to AzDo (#2880)
- [Profiler] Measure profiled and real allocations count/size (#3698)
- [Profiler] Migrate profiler windows integration tests to AzDo (#3737)
- [Profiler] Fix integration tests not running (#3748)
- [Profiler] New scenario: Add endpoint with dots (#3756)
- [AAS/Profiler] Allow sending profiles if Tracer is deactivated (#3697)
Debugger
- [Debugger] Limit snapshot size (#3709)
- [Dynamic Instrumentation] Perf improvements + Added probe metadata payload (#3725)
- [Dynamic Instrumentation] Display interface properties in snapshot (#3761)
Miscellaneous
- Only Check Clsid32 Key If Tracer < 2.14 (#3549)
- Stop using the CorProfiler singleton in rejit logic (#3670)
- [Test Package Versions Bump] Updating package versions (#3691)
- Clean up codebase using clang-tidy (#3716)
- Adds the
ci crank-import
command (#3722) - Wrap DbCommand.Connection getter with a try/catch (#3730)
- [Tracer] Check that the file in
DD_NATIVELOADER_CONFIGFILE
exists before using it (#3738) - Record the MVID of a loaded assembly in dependency telemetry (#3746)
Build / Test
- Add comparison of execution benchmarks posting to PR (#3672)
- Remove sync-over-async from AWS integration and fix flake (#3695)
- Add tests that we never write general ambient env vars to the logs (#3712)
- Force all tests to run as part of scheduled builds on
master
(#3724) - Fix osx folder in GetNativeLoaderPath() (#3733)
- Add throughput tests for manual instrumentation scenarios (#3734)
- Make the log output digestable by system tests dashboard (#3739)
2.22.0
Summary
Tracer
- Adds beta support for configuration
DD_TRACE_OTEL_ENABLED
. When set to true and automatic instrumentation is enabled for the application, you can use the OpenTelemetry API to generate Datadog spans. This setting will also allow you to get traces for libraries that we do not instrument yet if they do useSystem.Diagnostics
to report their activity. This feature is currently in beta and we welcome feedback to improve it.
Continuous Profiler
- Fix deadlock found in 2.21 (Linux)
- Live heap profiling beta with
DD_PROFILING_HEAP_ENABLED
set to1
Changes
Tracer
- [Tracer] Add OpenTelemetry Resources as span tags (#3572)
- [Tracer] W3C Trace Context part 3: include additional vendor values in
tracestate
header (#3578) - [Tracer] W3C Trace Context part 4: change default header settings (#3583)
- [Tracer] Fix sending multiple logs via DirectLogSubmission when using sub-loggers (#3589)
- [Tracer] Detect the actual Redis server when connecting to a cluster (#3594)
- [Tracer] Add support for Couchbase 3.4.1 (#3596)
- [Tracer] Small clean-up in
TraceContext.AddSpan()
(#3598) - [Tracer] Allow throwing exception of type CallTargetBubbleUpException in call target integrations (#3608)
- [Tracer] Fix Remote Configuration Service Name not being sent as lower-case + added more DEBUG-level logging (#3614)
- [Tracer] W3C Trace Context part 5: propagate
tracestate
in version-mismatch scenario (#3630) - [Tracer] Add missing private ctors to singleton propagators (#3631)
- [Tracer] Log the version of the native tracer in the managed logs (#3643)
- [Tracer] Wait for ReJIT request call to complete before returning from ModuleLoadFinished profiler callback (#3650)
- [Tracer] Support standardized name for polling env var (#3653)
- [Tracer] Simplify
ThreadSafeRandom
API (#3656) - [Tracer] Add a 100ms timeout on rejit request (#3664)
CI Visibility
- [CI Visibility] Reduce integrations required for NUnit testing framework (#3577)
- [CI Visibility] Code Coverage Payload Format v2 (#3588)
- [CI Visibility] Replace XUnit sync integration for flushing with an async one. (#3591)
- [CI Visibility] Update spec for azurepipelines with required env vars for correlation (#3592)
- [CI Visibility] Port some sync thread primitives to the async version (#3609)
- [CI Visibility] Fixes multiple thread access to the global coverage List<> with a lock (#3611)
- [CI Visibility] Remove stdout output from debug level in the CoverageCollector (#3612)
- [CI Visibility] Change GetAwaiter().GetResult() with AsyncUtil.RunSync() (#3615)
- [CI Visibility] Refactor MSTest integration and add support for nuget version 3.x (#3616)
- [CI Visibility] Enable IntelligentTestRunner configuration request by default (#3647)
- [CI Visibility] Fix dd-trace arguments handling (#3676)
- [CI Visibility] Add Logs to the dd-trace command (#3683)
- [CI Visibility] Modify the .deps.json file only when the Datadog.Trace.dll is copied (#3686)
- [CI Visibility] Fix casting error on ITR skip validator (#3689)
- [CI Visibility] Small changes to improve stability (#3693)
ASM
- [ASM] Stop throwing exception on unknown objects (#3553)
- [ASM] Adding missing usings to dispose (#3622)
- [ASM] Fix access violation memory exception (#3666)
Continuous Profiler
- [Profiler] Fix sanitizer jobs (#3181)
- [Profiler] Update the architecture to support heap profiling (#3445)
- [Profiler] Add MetricsRegistry (#3576)
- [Profiler] Detect and fix CPU overlaps (#3623)
- [Profiler] Add numeric labels (#3624)
- [Profiler] Fix warnings (#3634)
- [Profiler] Fix using nanoseconds instead of milliseconds (#3638)
- [Profiler] Provides an alternative stackwalk (#3642)
- [Profiler] Review log messages (#3648)
- [Profiler] Add a test scenario where short lived threads are created over and over again (#3649)
- [Profiler] Allow multiple scenarios to run sequentially in BuggyBits (#3655)
- [Profiler] Fix deadlock due to TLS initialization while unwinding (#3661)
- [Profiler] Fix text error (#3667)
- [Profiler] Check max CPU/Wall time consumption in tests (#3673)
- [Profiler] Remove internal metrics (#3678)
Debugger
- [Dynamic Instrumentation] Added missing tags to
RcmClientTracer
(#3405) - [Dynamic Instrumentation] Added messages to erroneous probe statuses (#3582)
- [Debugger] Run integrations tests with different debug type and optimizations (#3618)
- [Dynamic Instrumentation] Implement expression evaluator, conditions and log probes (#3688)
- [Debugger] Add default sampling rate for log probes (#3692)
Serverless
- Add delay to serverless tests to reduce flakiness (#3619)
Fixes
- Modernize C++ code (#3551)
Build / Test
- [Test Package Versions Bump] Updating package versions (#3540)
- Add integration tests for OWIN apps hosted on Microsoft.Owin.Host.SystemWeb (#3558)
- Exclude some processes from being profiled in nuke targets (#3568)
- Move maximum possible tasks from
Datadog.Trace.proj
toNuke
(#3573) - Increase timeout for agent malfunction flaky test. (#3574)
- Improves ExitCodeException (#3580)
- Upload crank throughput results to AzDo artifacts (#3581)
- Removes Task.Delay dependency on TaskContinuation tests (#3584)
- Minor build fixes when testing all package versions (#3590)
- [Tracer/Native loader] Run tracer and native loader native unit tests (#3593)
- Update global.json to pin to the only supported version of the SDK (#3601)
- [Test Package Versions Bump] Updating package versions (#3602)
- Add testing against multiple package versions for OpenTelemetry.Api (#3604)
- Adds debugger break environment variable (#3613)
- Allow to build native code in Debug on Linux from Nuke (#3627)
- Write throughput results as a PR comment (#3628)
- Rework build to always build for AnyCPU instead of x64/x86 (#3632)
- Bump sdk used in CI to 7.0.101 (#3633)
- [Tracer] Update span metadata rules documentation with integration names (#3635)
- Allow azure upload via a variable (#3637)
- Fix CodeQL action and GitLab build (#3645)
- Fix execution time (startup time) benchmarks and save artifacts (#3654)
- [Tests] Refactor ASM integration tests to use IClassFixture for application and agent (#3657)
- Fix path to FakeDbCommand in execution time benchmarks (#3658)
- Drop SDK in global.json down to 7.0.100 (#3659)
- Add missing dependencies to
build_runner_tool_and_standalone
stage (#3665) - [Tests] Enable the parametric test suite from the system-tests repo (#3675)
- Log the PID in more test paths (#3677)
Miscellaneous
2.21.0
Summary
Warning We identified a bug in the .NET Runtime in .NET 5+ that can cause crashes in rare cases. You can mitigate the issue by setting
DD_INTERNAL_WORKAROUND_77973_ENABLED=1
. However, this disables tiered JIT in affected runtimes (.NET 5, .NET 6, .NET 7), which may have a significant impact on application throughput.Note that setting this flag will have no effect or impact when set for unaffected runtimes. The root issue in the .NET runtime has been resolved and will be released in versions
6.0.13
and7.0.2
of the runtime. No fix is available for .NET 5. Other .NET versions are not affected.⛔ The Linux .NET profiler in this version can deadlock managed threads due to stackwalking while allocating memory. This is fixed in #3661. In the meantime, we recommend to either use the 2.20, either disable the profiler by setting the environment variable
DD_PROFILING_ENABLED=0
. The fix will be shipped in 2.22
- [Tracer] Update ActivityListener to handle OpenTelemetry API methods
- [Profiler] Improve Linux stackwalk
- [CI Visibility] Improvements to Code Coverage
Changes
Tracer
- [tracer] W3C Trace Context part 2:
dd
values intracestate
header (#3491) - [CLI] Check if DD_TRACE_ENABLED is set And Log if set to false (#3500)
- Keep single sampled spans when stats enabled (#3536)
- Small refactor for managed logging (#3541)
- Add support for CallTarget async continuations (
OnAsyncMethodEnd
returning a Task) (#3555) - Updated Newtonsoft.Json to 13.0.2 (#3559)
- Adds a workaround for the dotnet runtime issue 77973 (#3506, #3579)
- Add environment variable DD_TRACE_OTEL_ENABLED (#3531)
- [Tracer] Update ActivityListener to handle OpenTelemetry API methods (#3556)
CI Visibility
- [CI Visibility] - Code Coverage rewrite and improvements (#3494)
- [CI Visibility] - Add validation for git metadata env vars (#3560)
- [CIVisibility] - Add CIVisibility known errors to the CheckBuildLogs task (#3564)
ASM
- asm/waf rules enabling (#3321)
- [ASM] Security refactoring : removing instrumentation gateway and simplifying (#3442)
- [ASM] Taint request parameters (#3513)
- [ASM] Taint request headers (#3563)
Continuous Profiler
- [Profiler] Improve Linux stackwalk (#3485)
- [Profiler] Bump libdatadog version from 0.9.0 to 1.0.0 (#3538)
- [Profiler] Move GC labels from enum to text (#3545)
- [Profiler] Bump libdatadog version from 1.0.0 to 1.0.1 (#3557)
- [Profiler] Remove per type allocation (#3561)
- [Profiler] Remove 100+ ms threshold for lock contention (#3565)
- [Profiler] Remove async call for parallel buggybits (#3569)
Debugger
- Move debugger tests to separate project (#3526)
- Fix bug which caused
DD_WRITE_INSTRUMENTATION_TO_DISK
to stop working (#3566) - [Debugger] Temporary disable debugger tests for
x86
, .net 3.1 and .net6.0 (#3575)
Fixes
- Refactor launchSettings.json to load the CLR Profiler from the monitoring-home directory (#3532)
Build / Test
- Add "analyze-instrumentation" command to dd-trace diagnostic tool (#3408)
- Test against
net462
to fix code coverage (#3520) - Log error code when fetching kafka topic (#3527)
- Set QUIC_LTTng=0 in docker images (#3529)
- Run arm64 and Lambda integration tests on .NET 7 (#3530)
- Add some output to the runtime metrics test (#3535)
- [Build] Add missing labels to auto labeller (#3537)
- Reduce number of testing frameworks in PRs (again) (#3542)
- Fix json fluent assertion comparion (#3546)
- UDS is a variant, not a scenario in system tests (#3567)
- Temporarily ignore error in logs from CI app (#3571)
2.20.0
Summary
- Adds support for .NET 7
- Allow client-side filtering of direct log submission logs using
ILogger
- [Profiler] Include GC pauses in profiles
- [Profiler] Improve Code Hotspots to include short spans
- [CI Visibility] Adds support for Buddy CI and improves intelligent test runner
- [Dynamic Instrumentation] Enables async method probes
Changes
Tracer
- [Tracer] refactor trace serialization part 3:
env
,version
, and_dd.origin
(#3316) - [tracer] W3C Trace Context part 1: update propagation style settings (#3446)
- Fix Single Span Sampling tags to be metrics (#3459)
- [Tracer] Use the correct
MessagePackStringCache
methods for origin and version (#3462) - Move SpanSampling tag names to Metrics.cs (#3469)
- [Tracer] Always add
SiteName
andSiteType
on AAS Tags and add tags in serialization (#3472) - Add support for .NET 7 (#3482)
- Add support for filtering
ILogger
for direct log submission (#3487) - Include "Datadog-Container-ID" as a header RCM's configuration requests (#3488)
- [Tracer] Add link to the public doc in the logs (#3493)
- [Tracer] Move AAS metadata in settings (#3517)
CI Visibility
- [CI Visibility] - Add a new helper method to the discovery service (#3441)
- [CI Visibility] - Add buddy ci provider support. (#3443)
- [CIVisibility] - Add fallback when pack-object returns a cross device error (#3458)
- [CIVisibility] Fix CIVisibility tests (#3463)
- [CI Visibility] - Add support for ITR backend rate limiting (#3490)
- [CI Visibility] Include Intelligent Test Runner stats tags in TestSession (#3524)
ASM
- update rules to 1.4.2 (#3418)
- [ASM] Add IAST request configuration variables (#3432)
- [ASM] Tainted map for IAST (#3450)
Continuous Profiler
- [Profiler] Replace usage of refcounted object by shared_ptr (#2981)
- [Profiler] Improve CodeHotspots (#3501)
- [Profiler] Fix clang tidy warnings (#3435)
- [Profiler] Add garbage collection in profile (#3476)
- [Profiler] Revisit the way Sample object are used (#3478)
Debugger
- [Dynamic Instrumentation] Improved the instrumentation of async line probes (#3426)
- [Dynamic Instrumentation] Enable async method probe (#3504)
- [Dynamic Instrumentation] Gracefully ignore byref-like types + Added TypeRef to TypeDef resolution functionality (#3505)
- [Dynamic Instrumentation] Fixed the lookup of Symbol Method of async methods (#3481)
Build / Test
- [Test Package Versions Bump] Updating package versions (#3383)
- Use our own VMSS for more builds (#3421)
- Fix builds being broken by "quoted things" in the commit message (#3438)
- Add missing entry to VSConfig (#3440)
- Don't use the DatadogTestLogger for local dev (#3444)
- [Build] macOS multitarget build support (x86_64 and arm64) from x64 mac (#3447)
- Update vsconfig some more (#3448)
- Add a webhook stage to the pipeline (#3449)
- [Build] - Add support for universal binary in osx (#3454)
- Bump DatadogTestLogger version (#3456)
- Pin the fpm version, because latest breaks the pipeline (#3457)
- Fix Exploration tests (#3470)
- Add Instrumentation Verification to AspNetCoreMinimalApisTests (#3474)
- Disable tiered compilation in integration tests (#3479)
- Avoid monitoring the dd-trace tool as it causes a crash on start-up (#3480)
- Handle GRPC test flakiness (#3484)
- Bump DatadogTestLogger version to 0.0.31 (#3492)
- Reduce flake by always choosing a random port for
MockTracerAgent
(#3496) - Reenable Large payload tests (#3498)
- [Tracer] Versions conflicts tests are back (#3502)
- Force English for .NET CLI in build scripts (#3508)
- Bump DatadogTestLogger to 0.0.32 (#3509)
- Create custom image for building in GitLab (#3510)
- Reduce number of frameworks tested in PRs (#3511)
- Normalize names of logs and snapshot artifacts for consistency (#3521)
- Limit the number of jobs to the number of cores when building native code on Linux (#3477)
- [Profiler] Bump cppcheck version (#3497)
- [Profiler] Fix Benchmark jobs (#3499)
- [Profiler] Fix Windows Throughput tests (#3503)
- [Profiler] Publish symbols and install procdump as postmortem debugger (#3512)
- [Profiler] Disable tiered compilation in integration tests (#3519)
- [Profiler] Export tracer native symbols in Github Actions (#3523)
- [Profiler] Disable tiered jit compilation only when Tracer is activated (#3525)
- [Profiler] Update actions to avoid noisy warnings (#3528)
Miscellaneous
2.19.0
Summary
Tracer
- IP Collection can now be enabled by setting
DD_TRACE_CLIENT_IP_ENABLED
(#3419) - Automatic cleanup of log files that are 31 days or older (#3346)
Changes
Tracer
Enhancements
- Allow colons in global tag values (
DD_TAGS
) (#3328) - Delete Log Files That are 31 Days or Older (#3346)
- Make RareSampler configurable (#3360)
- Move
SpanSampler
intoAgentWriter.WriteTrace
(#3381) - Handle client-disconnect scenario in IIS (#3395)
- [Tracer] Add stats_computation_enabled in startup logs (#3400)
- Read performance counter values directly from memory (#3403)
- [Tracer] Reintroduce opt-in ip collection (#3419)
Fixes
- Fix
ILogger
direct submission when formatter returnsnull
(#3398) - Fix ASP.NET and ASP.NET Core resource name template expansion (#3409)
- Update
SetTag()
source generator to avoid incorrect usage (#3415) - Add integration tests for Azure Functions and fix warning (#3422)
- Fix Azure Functions Runtime V4 distributed tracing (#3423)
CI Visibility
- [CI Visibility] - Add support for agent's event platform proxy. (#3322)
- Datadog Test Logger (#3355)
- [CIVisibility] - Test session visibility support (#3389)
- [CIVisibility] Fix EVP tests by turning off the DD_TRACE_DEBUG flag (#3402)
- Fix BenchmarkDotNet Exporter (#3416)
- [CIVisibility] - Add Test custom configurations support for ITR (#3417)
- [CI Visibility] - Add support for git shallow clone (#3424)
- [CI Visibility] - CheckAgentConnectionAsync rewrite to use the DiscoveryService. (#3433)
ASM
- [ASM] IAST request management (#3384)
Continuous Profiler
- [Profiler] Rename DD_PROFILING_CONTENTION_ENABLED to DD_PROFILING_LOCK_ENABLED (#3414)
Debugger
- [Dynamic Instrumentation] Activating line probe on async methods + Fixed snapshot serialization issues (#3406)
Build / Test
- Fix OSX managed loader issue. (#3386)
- Change list of expected modified files for release (#3387)
- Fix Pipeline when Pull Request variables are not available (#3388)
- Add missing dependencies to
coverage
andtraces_pipeline
stages (#3390) - Apply new PackageReference Conditional to fix IIS tests (#3394)
- Enable Test DataLogger (#3397)
- Small fixes for DatadogTestLogger (#3399)
- Bump version of DatadogTestLogger to remove direct reference to Datadog.Trace (#3401)
- Ensure test parameters are constant across test runs (#3404)
- Fix the env and service names for AppSec throughput tests and benchmarks (#3413)
- Add special ExitCodeException to test suites (#3425)
- Bump DatadogLogger version to 0.0.28 (#3427)
- [Build] Fix exported symbols issue with CMake builds (#3428)
2.18.0
Summary
Profiler
- AAS support
- Allocation and Contention profilers are available! Enable them with
DD_PROFILING_ALLOCATION_ENABLED=1
andDD_PROFILING_CONTENTION_ENABLED=1
respectively
Changes
Tracer
- Add
SpanRateLimiter
for Single Span Ingestion (#3282) - Add
SpanSamplingRule
for Single Span Ingestion (#3283) - Implement the SpanSampler into the Tracer (#3286)
- [Test Package Versions Bump] Updating package versions (#3300)
- [Tracer] refactor trace serialization part 2:
_sampling_priority_v1
(#3315) - [CI Visibility] - Add a final try to load the pdb from a module. (#3350)
- Make cgroup
ContainerMetadata
parsing more lenient (#3354) - [Test Package Versions Bump] Updating package versions (#3366)
- [Test Package Versions Bump] Updating package versions (#3376)
- Adding Tags Data to Span Started Logs (#3377)
CI Visibility
- [CI Visibility] - Add Intelligent Test Runner support in MSTest testing framework (#3341)
ASM
- [IAST] Implementation of the basic classes that will be used in IAST and the insecure hashing vulnerability detection (#3225)
- [ASM] Remove warnings and fix flake (#3338)
- [IAST] Weak cipher algorithms detection (#3353)
- [ASM] Deduplication of vulnerabilities (#3371)
- [ASM] Stop collecting IP if appsec is disabled, only collect ip for appsec (#3379)
Continuous Profiler
- [Profiler] Add support for named pipes (#3257)
- [Profiler] Sample allocation and contention profilers (#3268)
- [Profiler] Send only activated profilers values in profile (#3337)
- [Profiler] Ensure all sample have high precision timestamps (#3349)
- [Profiler] Save and restore the value of errno in the signal handler (#3370)
- [Profiler] Samples supports timestamps as label (#3372)
- [Profiler] Disable namedpipe flacky test on x86 until fix is found (#3380)
- [Profiler] Customize wall time and CPU sampling constants (#3382)
Serverless
- Update Samples.AWS.Lambda and tests (#3359)
- Add support for nested and generic arguments to Lambda handlers (#3367)
- Run serverless tests on .NET 5.0 and .NET 6.0 (#3369)
- Add better fallback for Lambda service name (#3378)
Fixes
- Fixes Apple Silicon Build (#3358)
- Fix fairly subtle bug with remote config feature ASM_DD (#3344)
- Minor remote config fixes (#3347)
- Close the logger on exit (#3374)
Build / Test
- Fix all build warnings and errors (#3324)
- [asm] Fix flake asm remote rules tests (#3334)
- Fix dotnet install in build (#3348)
- Exclude xml files from
dd-trace
tool and Datadog.Trace.Bundle (#3363) - Fix broken package version bump + add GitHub action (#3364)
- Increase allowed variation in
SpanSamplerTests
to fix flake (#3368)
Miscellaneous
2.17.0
Summary
- Fixes an error in instrumentation leading to an
InvalidProgramException
when certain code patterns are found in instrumented classes (first identified inEFCache
). This issue is present in all previous 2.x versions. - Fixes ASM one-click activation
Changes
Tracer
- Enable agent-based telemetry by default (#2800)
- [Tracer] refactor trace serialization part 1 (#3135)
- Add fix for method rewriter in non-void method with branch to last return (#3331)
- Add Data Streams Monitoring support when using manual instrumentation with Kafka (#3319)
CI Visibility
- [CIVisibility] Public Api fixes (#3330)
ASM
- Simplify blocking by updating the test rules (#3318)
- Use a different log file for tests using the log entry watcher (#3320)
- Correct index used by activation capability (#3333)
Continuous Profiler
- [Profiler] Bump libdatadog version to 0.9.0 (#3313)
Miscellaneous
- [Tracer] Use
Datadog.Trace.Bundle
inNugetDeployment
samples (#3273)
Build / Test
- Fix documentation URL (#3327)
2.16.0
Summary
- [ASM] IP Blocking by remote config
- [Tracer] Making
Datadog.Trace.Bundle
Nuget package Generally Available. This package contains the full Datadog .NET APM suite for Tracing (automatic, and custom), Continuous Profiler and Application Security Monitoring (ASM). - [Tracer] Add support for instrumenting interface methods, allowing for instance for more support of some RabbitMq libraries.
Changes
Tracer
- Data Stream Monitoring .NET implementation
- Initial data streams monitoring propagation (#3174)
- Add Kafka data streams monitoring implementation (#3192)
- Added support for
IDiscoveryService
toDataStreamsManager
(#3220) - Add checkpointing and aggregation for data streams monitoring (#3191)
- Fix edge case in
DataStreamsWriter
(#3304) - Disable DSM if
DD_TRACE_KAFKA_CREATE_CONSUMER_SCOPE_ENABLED=0
(#3311) - GZip the data streams monitoring data sent to the agent (#3249)
- Make sure we remove the DSM propagation header from SQS attributes (#3312)
- Send Telemetry heartbeat independently of flushed data (#3239)
- Remove unneeded logs (#3265)
- Try loading OpenSSL eagerly on
netcoreapp2.0
-net5.0
(#3284) - [Tracer] Add support for instrumenting interface methods (#3256)
- [Tracer] Rename
Datadog.Monitoring.Distrib
intoDatadog.Trace.Bundle
(#3263)
CI Visibility
- [CI Visibility] - Test API and Test Suite Visibility (#3276)
- [CI Visibility] - Initialize tracer earlier (#3295)
ASM
- [ASM] ASM_DATA - IP blocking data (#3235)
- [ASM] IP Blocking for .NET Framework (#3207)
- [ASM] upgrade waf and rules (#3274)
- [ASM] remote config update (#3120)
- [ASM] Fix asm RCM tests flakiness (#3266)
- [ASM][RCM] Reduce Flake > fix integration tests log watching (#3287)
- [ASM] Optimize blocking (#3306)
Continuous Profiler
- [Profiler] Fix throughput tests on Linux (#3246)
- [Profiler] Prevent profiler from getting stuck on lost signal (#3255)
- [Profiler] Fix deadlock on alpine on thread creation (#3288)
- [Profiler] Change message when exporting profile (#3290)
- [Profiler] Change lock-duration to lock-time (#3298)
- [Profiler] Initialize signal handler only once (#3308)
- [Profiler] Log INVOKE and CALL warning message only once (#3309)
- [Profiler] Change log level from error to info in StackSamplerLoopManager (#3314)
Debugger
- [Debugger] Adjust debugger snapshot json structure to new schema (#3297)
- [Debugger] Skip
DebuggerSnapshotCreatorTests.Limits_LargeDictionary
as it's flaky (#3310)
Serverless
Miscellaneous
- Remove useless logs (#3230)
- Update coreclr files to fix errors on Alpine (#3260)
- Fix endian bug (#3270)
Build / Test
- Throughput for blocking (#3277)
- Re-enable collecting crash dumps on Linux (#3227)
- Add ability to capture hang dumps on Linux (#3229)
- Update the list of expected file changes when doing a version bump (#3259)
- Samples.Probes must always be built (#3262)
- Bump timeouts in installer smoke tests (#3267)
- [CI] Fix permissions issue when uploading crash dumps on Linux in some cases (#3269)
- Exitcode should be zero (#3271)
- Give proper warning if the
createdump
tool crashes. (#3272) - Add Apple Silicon support on tracer builds (#3279)
- Improve gitlab deployment (#3285)
- Bump some timeouts to reduce test flake (#3289)
- Fix test version package bump (#3291)
- Skip flakey test ProbesTests.TransparentCodeCtorInstrumentationTest (#3296)
- Add a workaround for missing profiling support in PyPI version of dd-apm-test-agent (#3299)
- Remove workaround for missing profiler support in PyPI version of dd-apm-test-agent (#3303)
- Run IP blocking tests with default rules (#3307)
- Fix flaky
DataStreamsWriter
test (#3317)