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.
25
Microsoft.Extensions.Resilience
Extensions to the Polly libraries to enrich telemetry with metadata and exception summaries.
26
Microsoft.Extensions.Resilience
Extensions to the Polly libraries to enrich telemetry with metadata and exception summaries.
27
Microsoft.Extensions.Resilience
Extensions to the Polly libraries to enrich telemetry with metadata and exception summaries.
28
Microsoft.Extensions.Resilience
Extensions to the Polly libraries to enrich telemetry with metadata and exception summaries.
30
Microsoft.Extensions.Telemetry
Provides canonical implementations of telemetry abstractions
25
Microsoft.Extensions.Telemetry
Provides canonical implementations of telemetry abstractions
27
Microsoft.Extensions.Telemetry
Provides canonical implementations of telemetry abstractions.
26
Microsoft.Extensions.Telemetry
Provides canonical implementations of telemetry abstractions.
27
Microsoft.Extensions.Telemetry
Provides canonical implementations of telemetry abstractions.
28
Microsoft.Extensions.Telemetry
Provides canonical implementations of telemetry abstractions.
29
Microsoft.Extensions.Telemetry
Provides canonical implementations of telemetry abstractions.
33

Version Downloads Last updated
9.10.0 3 10/20/2025
9.9.0 5 09/15/2025
9.8.0 6 08/16/2025
9.7.0 8 07/12/2025
9.6.0 10 06/14/2025
9.5.0 10 05/17/2025
9.4.0 14 04/10/2025
9.3.0 15 03/31/2025
9.2.0 15 02/23/2025
9.1.0 17 01/31/2025
9.0.0 21 11/16/2024
9.0.0-preview.9.24507.7 20 11/20/2024
9.0.0-preview.8.24460.1 20 11/19/2024
9.0.0-preview.7.24412.10 21 11/19/2024
9.0.0-preview.6.24353.1 19 11/20/2024
9.0.0-preview.5.24311.7 19 11/19/2024
9.0.0-preview.4.24271.2 30 06/02/2024
9.0.0-preview.3.24209.3 25 06/02/2024
9.0.0-preview.2.24157.4 24 06/02/2024
9.0.0-preview.1.24108.1 26 06/02/2024
8.10.0 22 11/20/2024
8.9.1 20 11/20/2024
8.9.0 22 11/19/2024
8.8.0 22 11/19/2024
8.7.0 22 11/19/2024
8.6.0 23 11/20/2024
8.5.0 26 06/02/2024
8.4.0 23 06/02/2024
8.3.0 26 06/02/2024
8.2.0 27 06/02/2024
8.1.0 31 06/02/2024
8.0.0 23 06/02/2024
8.0.0-rc.2.23510.2 25 06/02/2024
8.0.0-rc.1.23453.1 22 06/02/2024
8.0.0-preview.7.23407.5 25 06/02/2024
8.0.0-preview.6.23360.2 21 06/02/2024
8.0.0-preview.5.23308.3 25 06/02/2024
8.0.0-preview.4.23273.7 25 06/02/2024