AWS.Lambda.Powertools.Metrics
2.2.0-alpha
Prefix Reserved
See the version list below for details.
dotnet add package AWS.Lambda.Powertools.Metrics --version 2.2.0-alpha
NuGet\Install-Package AWS.Lambda.Powertools.Metrics -Version 2.2.0-alpha
<PackageReference Include="AWS.Lambda.Powertools.Metrics" Version="2.2.0-alpha" />
<PackageVersion Include="AWS.Lambda.Powertools.Metrics" Version="2.2.0-alpha" />
<PackageReference Include="AWS.Lambda.Powertools.Metrics" />
paket add AWS.Lambda.Powertools.Metrics --version 2.2.0-alpha
#r "nuget: AWS.Lambda.Powertools.Metrics, 2.2.0-alpha"
#:package AWS.Lambda.Powertools.Metrics@2.2.0-alpha
#addin nuget:?package=AWS.Lambda.Powertools.Metrics&version=2.2.0-alpha&prerelease
#tool nuget:?package=AWS.Lambda.Powertools.Metrics&version=2.2.0-alpha&prerelease
AWS.Lambda.Powertools.Metrics
Metrics creates custom metrics asynchronously by logging metrics to standard output following Amazon CloudWatch Embedded Metric Format (EMF).
These metrics can be visualized through Amazon CloudWatch Console.
Key features
- Aggregate up to 100 metrics using a single CloudWatch EMF object (large JSON blob)
- Validate against common metric definitions mistakes (metric unit, values, max dimensions, max metrics, etc)
- Metrics are created asynchronously by CloudWatch service, no custom stacks needed
- Context manager to create a one off metric with a different dimension
Read the docs
For a full list of features go to docs.powertools.aws.dev/lambda/dotnet/core/metrics/
GitHub: https://github.com/aws-powertools/powertools-lambda-dotnet/
Sample Function
View the full example here: https://github.com/aws-powertools/powertools-lambda-dotnet/tree/develop/examples/Metrics
public class Function
{
/// <summary>
/// Lambda Handler
/// </summary>
/// <param name="apigwProxyEvent">API Gateway Proxy event</param>
/// <param name="context">AWS Lambda context</param>
/// <returns>API Gateway Proxy response</returns>
[Logging(LogEvent = true)]
[Metrics(CaptureColdStart = true)]
public async Task<APIGatewayProxyResponse> FunctionHandler(APIGatewayProxyRequest apigwProxyEvent,
ILambdaContext context)
{
var requestContextRequestId = apigwProxyEvent.RequestContext.RequestId;
Logger.LogInformation("Getting ip address from external service");
// Add Metric to capture the amount of time
Metrics.PushSingleMetric(
metricName: "CallingIP",
value: 1,
unit: MetricUnit.Count,
service: "lambda-powertools-metrics-example",
defaultDimensions: new Dictionary<string, string>
{
{ "Metric Type", "Single" }
});
var watch = Stopwatch.StartNew();
var location = await GetCallingIp();
watch.Stop();
Metrics.AddMetric("ElapsedExecutionTime", watch.ElapsedMilliseconds, MetricUnit.Milliseconds);
Metrics.AddMetric("SuccessfulLocations", 1, MetricUnit.Count);
var lookupRecord = new LookupRecord(lookupId: requestContextRequestId,
greeting: "Hello Powertools for AWS Lambda (.NET)", ipAddress: location);
try
{
Metrics.PushSingleMetric(
metricName: "RecordsSaved",
value: 1,
unit: MetricUnit.Count,
service: "lambda-powertools-metrics-example",
defaultDimensions: new Dictionary<string, string>
{
{ "Metric Type", "Single" }
});
await SaveRecordInDynamo(lookupRecord);
Metrics.AddMetric("SuccessfulWrites", 1, MetricUnit.Count);
return new APIGatewayProxyResponse
{
Body = JsonSerializer.Serialize(lookupRecord),
StatusCode = 200,
Headers = new Dictionary<string, string> { { "Content-Type", "application/json" } }
};
}
catch (Exception e)
{
Logger.LogError(e.Message);
return new APIGatewayProxyResponse
{
Body = e.Message,
StatusCode = 500,
Headers = new Dictionary<string, string> { { "Content-Type", "application/json" } }
};
}
}
}
Sample output
{
"_aws": {
"Timestamp": 1648181318790,
"CloudWatchMetrics": [
{
"Namespace": "AWSLambdaPowertools",
"Metrics": [
{
"Name": "CallingIP",
"Unit": "Count"
}
],
"Dimensions": [
[
"Metric Type"
],
[
"Service"
]
]
}
]
},
"Metric Type": "Single",
"Service": "lambda-powertools-metrics-example",
"CallingIP": 1
}
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | 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. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
-
net8.0
- Amazon.Lambda.Core (>= 2.5.0)
- AspectInjector (>= 2.8.1)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on AWS.Lambda.Powertools.Metrics:
Package | Downloads |
---|---|
AWS.Lambda.Powertools.Metrics.AspNetCore
Powertools for AWS Lambda (.NET) - Metrics AspNetCore package. |
GitHub repositories (3)
Showing the top 3 popular GitHub repositories that depend on AWS.Lambda.Powertools.Metrics:
Repository | Stars |
---|---|
aws/aws-lambda-dotnet
Libraries, samples and tools to help .NET Core developers develop AWS Lambda functions.
|
|
aws-samples/serverless-test-samples
This repository is designed to provide guidance for implementing comprehensive test suites for serverless applications.
|
|
aws-samples/serverless-dotnet-demo
|
Version | Downloads | Last Updated |
---|---|---|
3.0.1 | 196 | 10/21/2025 |
3.0.1-alpha | 173 | 10/15/2025 |
3.0.0 | 690 | 10/8/2025 |
2.2.0 | 1,856 | 9/25/2025 |
2.2.0-alpha3 | 190 | 9/22/2025 |
2.2.0-alpha2 | 246 | 9/22/2025 |
2.2.0-alpha | 223 | 9/19/2025 |
2.1.1 | 15,741 | 7/29/2025 |
2.1.0 | 3,688 | 7/15/2025 |
2.0.0 | 49,187 | 3/7/2025 |
2.0.0-alpha1 | 18,682 | 10/21/2024 |
1.8.1-alpha | 185 | 10/9/2024 |
1.7.1 | 163,033 | 7/12/2024 |
1.7.0-alpha3 | 164 | 7/14/2024 |
1.7.0-alpha2 | 131 | 7/12/2024 |
1.7.0-alpha | 2,735 | 2/21/2024 |
1.6.2 | 10,378 | 5/23/2024 |
1.6.1 | 40,908 | 3/10/2024 |
1.6.0 | 26,256 | 2/16/2024 |
1.5.3 | 42,269 | 11/16/2023 |
1.4.3 | 1,723 | 10/30/2023 |
1.4.2 | 11,336 | 9/19/2023 |
1.3.3 | 4,004 | 8/22/2023 |
1.3.2 | 4,685 | 6/29/2023 |
1.3.1 | 40,604 | 6/21/2023 |
1.2.0 | 13,135 | 5/5/2023 |
1.1.0 | 269 | 5/5/2023 |
1.0.1 | 15,289 | 4/6/2023 |
1.0.0 | 4,063 | 2/24/2023 |
0.0.3-preview | 171 | 9/18/2023 |
0.0.2-preview | 297 | 1/18/2023 |
0.0.1-preview.1 | 4,967 | 8/1/2022 |