Microsoft.Extensions.Telemetry.Abstractions 9.10.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);
The TagName attribute can be used to specify a custom tag name for each parameter or property. This is useful when you want to have more control over the naming of tags in your logs.
[LoggerMessage(1, LogLevel.Information, "My custom tag name: {my.custom.tagname}")]
public static partial void LogMyCustomTagName(
    this ILogger logger,
    [TagName("my.custom.tagname")] string name);
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.
Showing the top 20 packages that depend on Microsoft.Extensions.Telemetry.Abstractions.
| Packages | Downloads | 
|---|---|
| Microsoft.Extensions.Resilience Extensions to the Polly libraries to enrich telemetry with metadata and exception summaries. | 45 | 
| Microsoft.Extensions.Resilience Extensions to the Polly libraries to enrich telemetry with metadata and exception summaries. | 46 | 
| Microsoft.Extensions.Resilience Extensions to the Polly libraries to enrich telemetry with metadata and exception summaries. | 47 | 
| Microsoft.Extensions.Resilience Extensions to the Polly libraries to enrich telemetry with metadata and exception summaries. | 48 | 
| Microsoft.Extensions.Resilience Extensions to the Polly libraries to enrich telemetry with metadata and exception summaries. | 49 | 
| Microsoft.Extensions.Resilience Extensions to the Polly libraries to enrich telemetry with metadata and exception summaries. | 50 | 
| Microsoft.Extensions.Resilience Extensions to the Polly libraries to enrich telemetry with metadata and exception summaries. | 53 | 
| Microsoft.Extensions.Telemetry Provides canonical implementations of telemetry abstractions. | 45 | 
| Microsoft.Extensions.Telemetry Provides canonical implementations of telemetry abstractions. | 46 | 
| Microsoft.Extensions.Telemetry Provides canonical implementations of telemetry abstractions. | 47 | 
| Microsoft.Extensions.Telemetry Provides canonical implementations of telemetry abstractions. | 49 | 
.NET Framework 4.6.2
- Microsoft.Extensions.Compliance.Abstractions (>= 9.10.0)
- Microsoft.Extensions.Options (>= 8.0.2)
- Microsoft.Extensions.ObjectPool (>= 8.0.21)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.3)
.NET Standard 2.0
- Microsoft.Extensions.Options (>= 8.0.2)
- Microsoft.Extensions.ObjectPool (>= 8.0.21)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.3)
- Microsoft.Extensions.Compliance.Abstractions (>= 9.10.0)
.NET 9.0
- Microsoft.Extensions.Options (>= 9.0.10)
- Microsoft.Extensions.Logging.Abstractions (>= 9.0.10)
- Microsoft.Extensions.Compliance.Abstractions (>= 9.10.0)
- Microsoft.Extensions.ObjectPool (>= 9.0.10)
.NET 8.0
- Microsoft.Extensions.ObjectPool (>= 8.0.21)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.3)
- Microsoft.Extensions.Compliance.Abstractions (>= 9.10.0)
- Microsoft.Extensions.Options (>= 8.0.2)
| Version | Downloads | Last updated | 
|---|---|---|
| 9.10.0 | 8 | 10/15/2025 | 
| 9.9.0 | 21 | 09/11/2025 | 
| 9.8.0 | 19 | 08/14/2025 | 
| 9.7.0 | 34 | 07/09/2025 | 
| 9.6.0 | 32 | 06/12/2025 | 
| 9.5.0 | 30 | 05/16/2025 | 
| 9.4.0 | 46 | 04/10/2025 | 
| 9.3.0 | 46 | 04/01/2025 | 
| 9.2.0 | 47 | 03/31/2025 | 
| 9.1.0 | 40 | 04/01/2025 | 
| 9.0.0 | 39 | 03/31/2025 | 
| 9.0.0-preview.9.24507.7 | 49 | 04/01/2025 | 
| 9.0.0-preview.8.24460.1 | 48 | 04/01/2025 | 
| 9.0.0-preview.7.24412.10 | 52 | 03/31/2025 | 
| 9.0.0-preview.6.24353.1 | 44 | 04/01/2025 | 
| 9.0.0-preview.5.24311.7 | 41 | 04/01/2025 | 
| 9.0.0-preview.4.24271.2 | 38 | 03/31/2025 | 
| 9.0.0-preview.3.24209.3 | 48 | 04/01/2025 | 
| 9.0.0-preview.2.24157.4 | 46 | 03/31/2025 | 
| 9.0.0-preview.1.24108.1 | 46 | 03/31/2025 | 
| 8.10.0 | 47 | 04/01/2025 | 
| 8.9.1 | 40 | 03/31/2025 | 
| 8.9.0 | 43 | 04/01/2025 | 
| 8.8.0 | 41 | 04/01/2025 | 
| 8.7.0 | 41 | 03/31/2025 | 
| 8.6.0 | 41 | 04/01/2025 | 
| 8.5.0 | 38 | 03/31/2025 | 
| 8.4.0 | 42 | 03/31/2025 | 
| 8.3.0 | 46 | 04/01/2025 | 
| 8.2.0 | 41 | 04/01/2025 | 
| 8.1.0 | 46 | 03/31/2025 | 
| 8.0.0 | 43 | 04/01/2025 | 
| 8.0.0-rc.2.23510.2 | 45 | 04/01/2025 | 
| 8.0.0-rc.1.23453.1 | 48 | 03/31/2025 | 
| 8.0.0-preview.7.23407.5 | 43 | 04/01/2025 | 
| 8.0.0-preview.6.23360.2 | 45 | 04/01/2025 | 
| 8.0.0-preview.5.23308.3 | 41 | 04/01/2025 | 
| 8.0.0-preview.4.23273.7 | 44 | 04/01/2025 |