Microsoft.Extensions.Telemetry.Abstractions
8.6.0
Prefix Reserved
See the version list below for details.
dotnet add package Microsoft.Extensions.Telemetry.Abstractions --version 8.6.0
NuGet\Install-Package Microsoft.Extensions.Telemetry.Abstractions -Version 8.6.0
<PackageReference Include="Microsoft.Extensions.Telemetry.Abstractions" Version="8.6.0" />
paket add Microsoft.Extensions.Telemetry.Abstractions --version 8.6.0
#r "nuget: Microsoft.Extensions.Telemetry.Abstractions, 8.6.0"
// Install Microsoft.Extensions.Telemetry.Abstractions as a Cake Addin #addin nuget:?package=Microsoft.Extensions.Telemetry.Abstractions&version=8.6.0 // Install Microsoft.Extensions.Telemetry.Abstractions as a Cake Tool #tool nuget:?package=Microsoft.Extensions.Telemetry.Abstractions&version=8.6.0
Microsoft.Extensions.Telemetry.Abstractions
This package contains common abstractions for high-level telemetry primitives. Here are the main features it provides:
- Enhanced Logging Capabilities
- Log Enrichment
- Latency Measurement
- HTTP Request Metadata Handling
Install the package
From the command-line:
dotnet add package Microsoft.Extensions.Telemetry.Abstractions
Or directly in the C# project file:
<ItemGroup>
<PackageReference Include="Microsoft.Extensions.Telemetry.Abstractions" Version="[CURRENTVERSION]" />
</ItemGroup>
Usage
Enhanced Logging Capabilities
The package includes a custom logging generator that enhances the default .NET logging capabilities by replacing the default generator. This generator automatically logs the contents of collections and offers advanced logging features, significantly improving the debugging and monitoring process.
[LoggerMessage(1, LogLevel.Information, "These are the contents of my dictionary: {temperature}")]
internal static partial void LogMyDictionary(ILogger<Program> logger, Dictionary<int, string> temperature);
It also adds the LogProperties
attribute which can be applied to an object parameter of a LoggerMessage
method. It introspects the passed-in object and automatically adds tags for all its properties. This leads to more informative logs without the need for manual tagging of each property.
[LoggerMessage(1, LogLevel.Information, "Detected a new temperature: {temperature}")]
internal static partial void LogNewTemperature(ILogger<Program> logger, [LogProperties] Temperature temperature);
internal record Temperature(double value, TemperatureUnit unit);
Log Enrichment
Logging data can be enriched by adding custom log enrichers to the service collection. This can be done using specific implementations or generic types.
// Using a specific implementation
builder.Services.AddLogEnricher(new CustomLogEnricher());
// Using a generic type
builder.Services.AddLogEnricher<AnotherLogEnricher>();
Create custom log enrichers by implementing the ILogEnricher
interface.
public class CustomLogEnricher : ILogEnricher
{
public void Enrich(IEnrichmentTagCollector collector)
{
// Add custom logic to enrich log data
collector.Add("CustomTag", "CustomValue");
}
}
Latency Measurement
To track latency in an application it is possible to register checkpoint, measure, and tag names using the following methods:
builder.Services.RegisterCheckpointNames("databaseQuery", "externalApiCall");
builder.Services.RegisterMeasureNames("responseTime", "processingTime");
builder.Services.RegisterTagNames("userId", "transactionId");
Implement the ILatencyDataExporter
to export latency data. This can be integrated with external systems or logging frameworks.
public class CustomLatencyDataExporter : ILatencyDataExporter
{
public async Task ExportAsync(LatencyData data, CancellationToken cancellationToken)
{
// Export logic here
}
}
Use the latency context to track performance metrics in your application.
public void YourMethod(ILatencyContextProvider contextProvider)
{
var context = contextProvider.CreateContext();
var checkpointToken = context.GetCheckpointToken("databaseQuery");
// Start measuring
context.AddCheckpoint(checkpointToken);
// Perform operations...
// End measuring
context.AddCheckpoint(checkpointToken);
// Optionally, record measures and tags
context.RecordMeasure(context.GetMeasureToken("responseTime"), measureValue);
context.SetTag(context.GetTagToken("userId"), "User123");
}
Http Request Metadata Handling
The IDownstreamDependencyMetadata
interface is designed to capture and store metadata about the downstream dependencies of an HTTP request. This is particularly useful for understanding external service dependencies and their impact on your application's performance and reliability.
The IOutgoingRequestContext
interface provides a mechanism for associating metadata with outgoing HTTP requests. This allows you to enrich outbound requests with additional information that can be used for logging, telemetry, and analysis.
Feedback & Contributing
We welcome feedback and contributions in our GitHub repo.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Framework | net462 is compatible. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
-
.NETFramework 4.6.2
- Microsoft.Extensions.Compliance.Abstractions (>= 8.6.0)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.1)
- Microsoft.Extensions.ObjectPool (>= 8.0.5)
- Microsoft.Extensions.Options (>= 8.0.2)
-
net6.0
- Microsoft.Extensions.Compliance.Abstractions (>= 8.6.0)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.1)
- Microsoft.Extensions.ObjectPool (>= 8.0.5)
- Microsoft.Extensions.Options (>= 8.0.2)
-
net8.0
- Microsoft.Extensions.Compliance.Abstractions (>= 8.6.0)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.1)
- Microsoft.Extensions.ObjectPool (>= 8.0.5)
- Microsoft.Extensions.Options (>= 8.0.2)
NuGet packages (22)
Showing the top 5 NuGet packages that depend on Microsoft.Extensions.Telemetry.Abstractions:
Package | Downloads |
---|---|
Microsoft.Extensions.Telemetry
Provides canonical implementations of telemetry abstractions. |
|
Microsoft.Extensions.Resilience
Extensions to the Polly libraries to enrich telemetry with metadata and exception summaries. |
|
Microsoft.Extensions.Diagnostics.Testing
Hand-crafted fakes to make telemetry-related testing easier. |
|
Microsoft.Extensions.Diagnostics.ResourceMonitoring
Measures processor and memory usage. |
|
Microsoft.Extensions.Diagnostics.HealthChecks.Common
Health check implementations. |
GitHub repositories (2)
Showing the top 2 popular GitHub repositories that depend on Microsoft.Extensions.Telemetry.Abstractions:
Repository | Stars |
---|---|
open-telemetry/opentelemetry-dotnet
The OpenTelemetry .NET Client
|
|
destructurama/attributed
Use attributes to control how complex types are logged to Serilog.
|
Version | Downloads | Last updated |
---|---|---|
9.1.0 | 21,534 | 1/14/2025 |
9.0.0 | 910,433 | 11/12/2024 |
9.0.0-preview.9.24507.7 | 51,640 | 10/8/2024 |
9.0.0-preview.8.24460.1 | 32,628 | 9/10/2024 |
9.0.0-preview.7.24412.10 | 10,316 | 8/14/2024 |
9.0.0-preview.6.24353.1 | 10,018 | 7/10/2024 |
9.0.0-preview.5.24311.7 | 7,202 | 6/11/2024 |
9.0.0-preview.4.24271.2 | 11,616 | 5/21/2024 |
9.0.0-preview.3.24209.3 | 20,741 | 4/11/2024 |
9.0.0-preview.2.24157.4 | 4,500 | 3/12/2024 |
9.0.0-preview.1.24108.1 | 3,534 | 2/13/2024 |
8.10.0 | 1,854,216 | 10/8/2024 |
8.9.1 | 1,154,044 | 9/6/2024 |
8.9.0 | 67,626 | 9/5/2024 |
8.8.0 | 879,889 | 8/13/2024 |
8.7.0 | 1,348,684 | 7/10/2024 |
8.6.0 | 970,796 | 6/11/2024 |
8.5.0 | 1,159,953 | 5/14/2024 |
8.4.0 | 1,643,176 | 4/9/2024 |
8.3.0 | 725,637 | 3/12/2024 |
8.2.0 | 1,112,282 | 2/13/2024 |
8.1.0 | 533,450 | 1/9/2024 |
8.0.0 | 1,188,511 | 11/14/2023 |
8.0.0-rc.2.23510.2 | 36,879 | 10/10/2023 |
8.0.0-rc.1.23453.1 | 2,469 | 9/12/2023 |
8.0.0-preview.7.23407.5 | 3,526 | 8/8/2023 |
8.0.0-preview.6.23360.2 | 880 | 7/12/2023 |
8.0.0-preview.5.23308.3 | 3,015 | 6/14/2023 |
8.0.0-preview.4.23273.7 | 3,296 | 5/23/2023 |