Skip to main content

Health Checks Configuration

Health checks are an important part of any application for monitoring its health and dependencies. Endatix provides built-in health check functionality that is configured automatically by default.

Default Configuration

When you use builder.Host.ConfigureEndatix(), the following health checks are automatically configured:

  • Self-checks: Basic application health check
  • Process health: Memory usage monitoring
  • Disk space: Checking available disk space (where supported)
  • Database: Connection to your configured database

These health checks are exposed through the following endpoints:

  • /health: Basic health status (healthy, degraded, or unhealthy)
  • /health/detail: Detailed JSON report of all health checks
  • /health/ui: HTML UI showing health check results in a more readable format

Customizing Health Checks

Adding Custom Health Checks

You can add your own health checks to the default configuration:

builder.Host.ConfigureEndatixWithDefaults(endatix => {
// Add custom health checks
endatix.HealthChecks
.AddCheck("custom-service", () => HealthCheckResult.Healthy("Service is running"));
});

Database-Specific Health Checks

Endatix automatically adds the appropriate health check for your configured database provider:

// SQL Server health check
endatix.HealthChecks.AddSqlServer(
connectionString,
healthQuery: "SELECT 1;",
name: "database",
tags: new[] { "db", "sql" });

// PostgreSQL health check
endatix.HealthChecks.AddNpgSql(
connectionString,
healthQuery: "SELECT 1;",
name: "database",
tags: new[] { "db", "postgresql" });

Disabling Health Checks

If you need to completely disable health checks:

builder.Host.ConfigureEndatix(endatix => {
endatix.SkipHealthChecks();

// Rest of your configuration...
});

Configuring Health Check Endpoints

You can customize the health check endpoints when configuring middleware:

app.UseEndatix(options => {
options.UseHealthChecks = true;
options.HealthCheckPath = "/healthz"; // Changes base path from /health to /healthz
});

Advanced Usage

Filtering Health Checks

Health checks can be tagged for filtering. For example, to create an endpoint that only checks database health:

app.UseEndatix();

// Add a custom health check endpoint that only shows database checks
app.UseHealthChecks("/health/database", new HealthCheckOptions
{
Predicate = healthCheck => healthCheck.Tags.Contains("db")
});

Custom Health Check Implementation

For more complex health checks, you can implement the IHealthCheck interface:

public class MyServiceHealthCheck : IHealthCheck
{
private readonly IMyService _service;

public MyServiceHealthCheck(IMyService service)
{
_service = service;
}

public async Task<HealthCheckResult> CheckHealthAsync(HealthCheckContext context, CancellationToken cancellationToken = default)
{
try
{
var isHealthy = await _service.IsHealthyAsync(cancellationToken);

if (isHealthy)
{
return HealthCheckResult.Healthy("Service is healthy");
}

return HealthCheckResult.Degraded("Service is experiencing issues");
}
catch (Exception ex)
{
return HealthCheckResult.Unhealthy("Service is unhealthy", ex);
}
}
}

// Then register it:
endatix.HealthChecks.AddTypeActivatedCheck<MyServiceHealthCheck>("my-service");

UI Enhancements

For production environments, you might want to consider adding the HealthChecks.UI package which provides a more comprehensive dashboard for monitoring your application health.