Microsoft.Extensions.Telemetry.Abstractions 8.9.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.
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.
|
6 |
Microsoft.Extensions.Resilience
Extensions to the Polly libraries to enrich telemetry with metadata and exception summaries.
|
7 |
Microsoft.Extensions.Resilience
Extensions to the Polly libraries to enrich telemetry with metadata and exception summaries.
|
9 |
Microsoft.Extensions.Telemetry
Provides canonical implementations of telemetry abstractions
|
7 |
Microsoft.Extensions.Telemetry
Provides canonical implementations of telemetry abstractions
|
9 |
Microsoft.Extensions.Telemetry
Provides canonical implementations of telemetry abstractions
|
11 |
Microsoft.Extensions.Telemetry
Provides canonical implementations of telemetry abstractions
|
12 |
Microsoft.Extensions.Telemetry
Provides canonical implementations of telemetry abstractions.
|
6 |
Microsoft.Extensions.Telemetry
Provides canonical implementations of telemetry abstractions.
|
8 |
Microsoft.Extensions.Telemetry
Provides canonical implementations of telemetry abstractions.
|
9 |
Microsoft.Extensions.Telemetry
Provides canonical implementations of telemetry abstractions.
|
11 |
.NET Framework 4.6.2
- Microsoft.Extensions.Compliance.Abstractions (>= 8.9.0)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.1)
- Microsoft.Extensions.ObjectPool (>= 8.0.8)
- Microsoft.Extensions.Options (>= 8.0.2)
.NET 6.0
- Microsoft.Extensions.Compliance.Abstractions (>= 8.9.0)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.1)
- Microsoft.Extensions.ObjectPool (>= 8.0.8)
- Microsoft.Extensions.Options (>= 8.0.2)
.NET 8.0
- Microsoft.Extensions.Compliance.Abstractions (>= 8.9.0)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.1)
- Microsoft.Extensions.ObjectPool (>= 8.0.8)
- Microsoft.Extensions.Options (>= 8.0.2)
Version | Downloads | Last updated |
---|---|---|
9.0.0 | 3 | 11/16/2024 |
9.0.0-preview.9.24507.7 | 3 | 11/20/2024 |
9.0.0-preview.8.24460.1 | 3 | 11/19/2024 |
9.0.0-preview.7.24412.10 | 3 | 11/19/2024 |
9.0.0-preview.6.24353.1 | 3 | 11/20/2024 |
9.0.0-preview.5.24311.7 | 3 | 11/19/2024 |
9.0.0-preview.4.24271.2 | 11 | 06/02/2024 |
9.0.0-preview.3.24209.3 | 8 | 06/02/2024 |
9.0.0-preview.2.24157.4 | 6 | 06/02/2024 |
9.0.0-preview.1.24108.1 | 9 | 06/02/2024 |
8.10.0 | 3 | 11/20/2024 |
8.9.1 | 3 | 11/20/2024 |
8.9.0 | 3 | 11/19/2024 |
8.8.0 | 3 | 11/19/2024 |
8.7.0 | 3 | 11/19/2024 |
8.6.0 | 3 | 11/20/2024 |
8.5.0 | 7 | 06/02/2024 |
8.4.0 | 7 | 06/02/2024 |
8.3.0 | 7 | 06/02/2024 |
8.2.0 | 6 | 06/02/2024 |
8.1.0 | 6 | 06/02/2024 |
8.0.0 | 5 | 06/02/2024 |
8.0.0-rc.2.23510.2 | 6 | 06/02/2024 |
8.0.0-rc.1.23453.1 | 6 | 06/02/2024 |
8.0.0-preview.7.23407.5 | 8 | 06/02/2024 |
8.0.0-preview.6.23360.2 | 6 | 06/02/2024 |
8.0.0-preview.5.23308.3 | 8 | 06/02/2024 |
8.0.0-preview.4.23273.7 | 10 | 06/02/2024 |