DotNetStartupGuard 1.0.0

dotnet add package DotNetStartupGuard --version 1.0.0
                    
NuGet\Install-Package DotNetStartupGuard -Version 1.0.0
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="DotNetStartupGuard" Version="1.0.0" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="DotNetStartupGuard" Version="1.0.0" />
                    
Directory.Packages.props
<PackageReference Include="DotNetStartupGuard" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add DotNetStartupGuard --version 1.0.0
                    
#r "nuget: DotNetStartupGuard, 1.0.0"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package DotNetStartupGuard@1.0.0
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=DotNetStartupGuard&version=1.0.0
                    
Install as a Cake Addin
#tool nuget:?package=DotNetStartupGuard&version=1.0.0
                    
Install as a Cake Tool

DotNetStartupGuard

Validates application startup configuration, ensures ports are listening, and prevents silent startup failures.

Problems Solved

  • Port not listening: Application starts but port isn't actually listening
  • Silent crashes: Application crashes during startup without clear error messages
  • Kestrel binding issues: Port binding failures not detected early
  • IIS vs Kestrel confusion: Configuration differences between hosting environments
  • Blocking startup code: Synchronous blocking code in Program.cs hangs startup
  • Database connection hangs: Startup hangs waiting for database connection
  • Missing environment variables: Required environment variables not set in production
  • Wrong environment loaded: Production code running with development configuration
  • Docker startup failures: Container startup issues not detected
  • Missing health checks: No validation that application is ready to serve requests

Installation

dotnet add package DotNetStartupGuard

Quick Start

1. Validate Required Configuration

Problem: Missing configuration keys cause runtime failures in production.

using DotNetStartupGuard;

// ✅ GOOD: Validate configuration on startup
builder.Services.AddStartupValidation(validator =>
{
    validator.RequireEnvironmentVariable("DATABASE_CONNECTION_STRING");
    validator.RequireConfigurationKey("AppSettings:ApiKey");
    validator.RequirePortListening(5000);
});

// Validate after building the app
var app = builder.Build();
await app.ValidateStartupAsync();

2. Environment Variable Validation

Problem: Missing environment variables cause runtime errors.

// ❌ BAD: No validation, fails at runtime
var connectionString = Environment.GetEnvironmentVariable("DB_CONNECTION");

// ✅ GOOD: Validate on startup
EnvironmentHelper.RequireEnvironmentVariables(
    logger,
    "DATABASE_CONNECTION_STRING",
    "API_KEY",
    "REDIS_CONNECTION_STRING"
);

3. Port Listening Validation

Problem: Application claims to be running but port isn't listening.

// ✅ GOOD: Verify port is actually listening
var validator = new StartupValidator(configuration, logger);
validator.RequirePortListening(5000);
await validator.ValidateAsync();

4. Environment Detection

Problem: Wrong environment configuration loaded (dev config in production).

// ✅ GOOD: Validate environment is correct
EnvironmentHelper.ValidateEnvironment(
    configuration,
    logger,
    "Production", "Staging" // Only allow these environments
);

// Detect Docker environment
if (EnvironmentHelper.IsRunningInDocker())
{
    logger.LogInformation("Running in Docker container");
}

5. Health Checks for Startup

Problem: No way to verify application is ready to serve requests.

// ✅ GOOD: Add startup health checks
builder.Services.AddStartupHealthChecks()
    .AddDatabaseCheck()
    .AddPortCheck(5000)
    .AddEnvironmentVariableCheck("DATABASE_CONNECTION_STRING");

// Health check endpoint
app.MapHealthChecks("/health");

Real-World Example

var builder = WebApplication.CreateBuilder(args);

// Add startup validation
builder.Services.AddStartupValidation(validator =>
{
    // Validate environment variables
    validator.RequireEnvironmentVariable("DATABASE_CONNECTION_STRING");
    validator.RequireEnvironmentVariable("REDIS_CONNECTION_STRING");
    
    // Validate configuration keys
    validator.RequireConfigurationKey("AppSettings:ApiKey");
    validator.RequireConfigurationKey("AppSettings:JwtSecret");
    
    // Validate port is available
    validator.RequirePortListening(5000);
});

// Add health checks
builder.Services.AddStartupHealthChecks()
    .AddDatabaseCheck()
    .AddPortCheck(5000);

var app = builder.Build();

// Validate before running
await app.ValidateStartupAsync();

// Validate environment
EnvironmentHelper.ValidateEnvironment(
    app.Configuration,
    app.Logger,
    "Production", "Staging"
);

app.Run();

Complete Startup Validation Example

public class Program
{
    public static async Task Main(string[] args)
    {
        var builder = WebApplication.CreateBuilder(args);
        
        // Configure services
        builder.Services.AddControllers();
        builder.Services.AddDbContext<AppDbContext>(options =>
            options.UseSqlServer(builder.Configuration.GetConnectionString("DefaultConnection")));
        
        // Add startup validation
        builder.Services.AddStartupValidation(validator =>
        {
            validator.RequireEnvironmentVariable("DATABASE_CONNECTION_STRING");
            validator.RequireConfigurationKey("AppSettings:ApiKey");
        });
        
        // Add health checks
        builder.Services.AddStartupHealthChecks()
            .AddDatabaseCheck()
            .AddPortCheck(5000);
        
        var app = builder.Build();
        
        // Validate startup before accepting requests
        try
        {
            await app.ValidateStartupAsync();
            app.Logger.LogInformation("Startup validation passed");
        }
        catch (StartupValidationException ex)
        {
            app.Logger.LogCritical(ex, "Startup validation failed");
            Environment.Exit(1);
        }
        
        app.MapControllers();
        app.MapHealthChecks("/health");
        
        app.Run();
    }
}

Best Practices

  1. Validate all required configuration before accepting requests
  2. Check environment variables that are required for operation
  3. Verify ports are listening to catch binding issues early
  4. Use health checks to verify application readiness
  5. Validate environment to prevent wrong config in production
  6. Fail fast - exit immediately if validation fails

API Reference

  • StartupValidator - Validates configuration, environment variables, and ports
  • EnvironmentHelper - Utilities for environment variable validation
  • StartupHealthChecks - Health check implementations for startup validation
  • AddStartupValidation() - Extension method to add validation to services
  • ValidateStartupAsync() - Extension method to validate on app startup
Product 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
1.0.0 127 1/5/2026

Initial release. App startup validation and hosting helpers to ensure ports are listening, validate configuration, and handle startup failures gracefully.