This repository is dedicated to providing custom implementations of IHealthCheck
for .NET applications, offering additional health monitoring capabilities beyond the default checks.
- Uptime Health Check: Monitor the uptime of your application, adding startup time and uptime information to your health reports.
- .NET SDK ≥ 9.0.100
- Microsoft.Extensions.Diagnostics.HealthChecks ≥ 9.0.100
- An existing .NET application to integrate the health checks into
You can add the Uptime Health Check to your project via NuGet:
dotnet add package HealthChecks.Uptime
In your Startup.cs or wherever you configure services, add the uptime health check:
using HealthChecks.Uptime;
public void ConfigureServices(IServiceCollection services)
{
// Your existing service configurations
services.AddHealthChecks()
.AddUptimeHealthCheck();
}
By setting a threshold, the healthcheck status will return degraded until the configured amount of time in seconds has passed.
using HealthChecks.Uptime;
public void ConfigureServices(IServiceCollection services)
{
// Your existing service configurations
services.AddHealthChecks()
.AddUptimeHealthCheck((options) => {
options.DegradedThresholdInSeconds = 120;
});
}
Configure the health check endpoint in your application's request pipeline:
app.UseHealthChecks("/_health", new HealthCheckOptions
{
ResponseWriter = UIResponseWriter.WriteHealthCheckUIResponse,
AllowCachingResponses = false
});
Tip
Add the AspNetCore.HealthChecks.UI.Client
package to make use of the UIResponseWriter
class and give the Status
property a user-friendly translation to text.
You can create the Health Check report manually by getting an instance of the HealthCheckService
and calling CheckHealthAsyn()
as below;
// Where _provider is a local DI instance of `IServiceProvider`.
var healthCheckService = _provider.GetService<HealthCheckService>();
if (healthCheckService == null)
{
// Optionally, return a meaningful response or handle the logic as required
return JsonSerializer.Serialize(new { Error = "HealthCheckService is not available." });
}
var response = await healthCheckService.CheckHealthAsync();
var options = new JsonSerializerOptions
{
WriteIndented = true, // For pretty-printing. Set to false in production for compact JSON.
PropertyNamingPolicy = JsonNamingPolicy.CamelCase, // Common convention for JSON property names.
IgnoreNullValues = true // Optional: depending on whether you want to include properties with null values.
};
string jsonReport = JsonSerializer.Serialize(response, options);
The below JSON sample is representative of the output from both the manual report and from endpoint.
{
"status": "Healthy",
"totalDuration": "00:00:00.0000202",
"entries": {
"startup_time": {
"data": {
"Startup Time": "2024-02-27T09:41:49.7002848+00:00",
"Uptime": "08:23:57.5520239"
},
"description": "Application has been running without issues.",
"duration": "00:00:00.0000202",
"status": "Healthy",
"tags": []
}
}
}