Overview

ASP.NET reads the following environment variables to determine the environment:

  1. DOTNET_ENVIRONMENT
  2. ASPNETCORE_ENVIRONMENT

For WebApplicationBuilder (the default), DOTNET_ENVIRONMENT has precedence.
For WebHost (ConfigureWebHostDefaults, CreateDefaultBuilder), ASPNETCORE_ENVIRONMENT has precedence.

IHostEnvironment.EnvironmentName

  • The launchSettings.json file sets ASPNETCORE_ENVIRONMENT to Development on the local machine.
  • Set to Production if ASPNETCORE_ENVIRONMENT and DOTNET_ENVIRONMENT have not been set.

setting environment from command line

dotnet run --environment Production

development environment

launchSettings.json

The environment for local machine development can be set in Properties/launchSettings.json.

  • Is used only on the local development machine
  • Is not deployed
  • Contains profile settings
  • Environment values set in this file override values in the system environment
{
  "iisSettings": {
    "windowsAuthentication": false,
    "anonymousAuthentication": true,
    "iisExpress": {
      "applicationUrl": "http://localhost:59481",
      "sslPort": 44308
    }
  },
  "profiles": {
    "EnvironmentsSample": { // A profile; since this one is listed first, it is used by default
      "commandName": "Project", // If command name is "Project", Kestrel is used as web server
      "dotnetRunMessages": true,
      "launchBrowser": true,
      "applicationUrl": "https://localhost:7152;http://localhost:5105",
      "environmentVariables": {
        "ASPNETCORE_ENVIRONMENT": "Development"
      }
    },
    "IIS Express": { // Another profile
      "commandName": "IISExpress", // IISExpress is used as web server
      "launchBrowser": true,
      "environmentVariables": {
        "ASPNETCORE_ENVIRONMENT": "Development"
      }
    }
  }
}

selecting profiles from command line

dotnet run --launch-profile "profile-name"

  • Note: this approach only supports Kestrel profiles

production environment

Common settings for production environment:

  • Caching
  • Client-side resources bundled, minified, and potentially served from CDN
  • Diagnostic error pages disabled
  • Friendly error pages enabled
  • Production logging and monitoring

Note: If the environment is not set, it defaults to production.

set environment with vs code

The commandName property specifies the web server to launch: IISExpress, IIS (no web server launched; expects IIS to be available), or Project.

In Visual Studio Code, the environment variables can be set in .vscode/launch.json:

{
    "version": "0.2.0",
    "configurations": [
        {
            "name": ".NET Core Launch (web)",
            "type": "coreclr",
            // Configuration omitted for brevity.
            "env": {
                "ASPNETCORE_ENVIRONMENT": "Development",
                "ASPNETCORE_URLS": "https://localhost:5001",
                "ASPNETCORE_DETAILEDERRORS": "1",
                "ASPNETCORE_SHUTDOWNTIMEOUTSECONDS": "3"
            },
            // Configuration omitted for brevity.
          }

set environment with environment variables

For the current session:

$Env:ASPNETCORE_ENVIRONMENT = "Staging"
dotnet run --no-launch-profile # Must use no launch profile since launchSettings.json overrides environment variables

For all sessions globally:

[Environment]::SetEnvironmentVariable("ASPNETCORE_ENVIRONMENT", "Staging", "Machine")
dotnet run --no-launch-profile # Must use no launch profile since launchSettings.json overrides environment variables

set environment in code

var builder = WebApplication.CreateBuilder(new WebApplicationOptions
{
    EnvironmentName = Environments.Staging
}); 
// ...