分别生成了三个环境变量的配置文件:
以及测试代码:
public void Configure(IApplicationBuilder app, IHostingEnvironment env) { app.Run(async (context) => { context.Response.ContentType = "text/plain; charset=utf-8"; await context.Response.WriteAsync($"进程内环境变量:env.EnvironmentName={env.EnvironmentName}\n"); var myEnvironmentValue = Environment.GetEnvironmentVariable("ASPNETCORE_ENVIRONMENT", EnvironmentVariableTarget.Machine); await context.Response.WriteAsync($"操作系统环境变量 ASPNETCORE_ENVIRONMENT={myEnvironmentValue ?? "没有找到"}\n"); var connectionString = Configuration["ConnectionStrings:RicoDbContext"]; await context.Response.WriteAsync($"数据库库连接字符串:{connectionString}\n"); var appId = Configuration["AppId"]; await context.Response.WriteAsync($"appId={appId ?? "没找到"}\n"); }); }
首先来使用dotnet run
命令运行一下,命令运行在如下目录:
>dotnet run Hosting environment: Development Content root path: D:\02-github\rocklee2015\RicoNetCore\000-NetCoreBaseSample\S01-MultiEnviromentConfig Now listening on: http://localhost:5001 Application started. Press Ctrl+C to shut down.
为啥环境是Development
呢?,因为是按顺序读取launchSettings
第一个值,如果将Staging
放第一个就不一样了。
可以看到结果,环境变量变更了:
>dotnet run Hosting environment: Staging Content root path: D:\02-github\rocklee2015\RicoNetCore\000-NetCoreBaseSample\S01-MultiEnviromentConfig Now listening on: http://localhost:5001 Application started. Press Ctrl+C to shut down.
也可以使用dotnet run --launch-profile <name>
自定义启动配置文件:
>dotnet run --launch-profile Production Hosting environment: Production Content root path: D:\02-github\rocklee2015\RicoNetCore\000-NetCoreBaseSample\S01-MultiEnviromentConfig Now listening on: http://localhost:5001 Application started. Press Ctrl+C to shut down.
浏览器打开http://localhost:5001
,可以看到效果:
env.EnvironmentName
的值是Production
刚才自定义的环境,操作系统的全局环境变量ASPNETCORE_ENVIRONMENT
值是Production
也是对的,因为我设置的就是这个:
切换一下当前窗口的启动配置文件:
>dotnet run --launch-profile Staging Hosting environment: Staging Content root path: D:\02-github\rocklee2015\RicoNetCore\000-NetCoreBaseSample\S01-MultiEnviromentConfig Now listening on: http://localhost:5001 Application started. Press Ctrl+C to shut down.
可以看到读取的配置文件只受当前窗口的启动配置文件影响,即launchSettings
文件。不受全局环境变量影响。
在官方文档在 ASP.NET Core 中使用多个环境介绍中,可以在当前会话窗口的设置环境变量,使用以下命令:
set ASPNETCORE_ENVIRONMENT=Development
操作结果如下:
>set ASPNETCORE_ENVIRONMENT=Development >dotnet run Hosting environment: Staging Content root path: D:\02-github\rocklee2015\RicoNetCore\000-NetCoreBaseSample\S01-MultiEnviromentConfig Now listening on: http://localhost:5001 Application started. Press Ctrl+C to shut down.
当前窗口的全局环境变量似乎没有起作用!!
我将以上的项目发布成IIS部署包,结果如下:
可以看到使用的环境变量是Development
而不是默认的Production
,全局环境变量是Production
也没起什么作用?
官方说可以使用以下配置IIS的环境变量:
对于net core 2.2
版本来说一直报错HTTP Error 502.5 - Process Failure
(详见HTTP Error 500.30 - ANCM In-Process Start Failure)
dotnet run
命令环境变量加载的是启动配置文件。launchSettings
这三个取值优先级是怎样的?