ASP.NET Core启动地址配置方法及优先级顺序 | .NET 6 版本
前言
上次,我們討論了如何通過(guò)配置或代碼方式修改啟動(dòng)地址:《ASP.NET Core啟動(dòng)地址配置方法及優(yōu)先級(jí)順序》。不過(guò)是基于 .NET 5 版本的。
由于 .NET 6 使用了最小 WEB API, 配置方式已經(jīng)部分發(fā)生了變化。
設(shè)置方法
1. applicationUrl 屬性
launchSettings.json 文件中的 applicationUrl 屬性,但是僅在本地開發(fā)計(jì)算機(jī)上使用:
"profiles":?{"WebApplication1":?{..."applicationUrl":?"http://localhost:5100",} }2.環(huán)境變量
環(huán)境變量 ASPNETCORE_URLS,有多個(gè)設(shè)置位置,下面演示的是使用 launchSettings.json 文件:
"profiles":?{"WebApplication1":?{..."environmentVariables":?{"ASPNETCORE_URLS":?"http://localhost:5200"}} }3.命令行參數(shù)
命令行參數(shù) --urls,有多個(gè)設(shè)置位置,下面演示的是使用 launchSettings.json 文件:
"profiles":?{"WebApplication1":?{..."commandLineArgs":?"--urls?http://localhost:5300",} }4. UseUrls 方法
.NET 5 版本
修改 ConfigureWebHostDefaults 方法:
public?static?IHostBuilder?CreateHostBuilder(string[]?args)?=>Host.CreateDefaultBuilder(args).ConfigureWebHostDefaults(webBuilder?=>{webBuilder.UseStartup<Startup>();webBuilder.UseUrls("http://localhost:5400");});.NET 6 版本
對(duì)應(yīng)的方法為 WebApplicationBuilder.WebHost.UseUrls:
var?builder?=?WebApplication.CreateBuilder(args);builder.WebHost.UseUrls("http://localhost:5400");但是,運(yùn)行后不起作用。
結(jié)果發(fā)現(xiàn)這是 .NET 6 的 BUG (Builder.WebHost.UseUrls does not seem to override default url),并將在 6.0.3 中修復(fù):https://github.com/dotnet/aspnetcore/issues/38185
5. UseKestrel 方法
.NET 5 版本
修改ConfigureWebHostDefaults方法:
public?static?IHostBuilder?CreateHostBuilder(string[]?args)?=>Host.CreateDefaultBuilder(args).ConfigureWebHostDefaults(webBuilder?=>{webBuilder.UseStartup<Startup>();webBuilder.UseKestrel(options=>?options.ListenLocalhost(5500,?opts?=>?opts.Protocols?=?HttpProtocols.Http1));});.NET 6 版本
對(duì)應(yīng)的方法為 WebApplicationBuilder.WebHost.ConfigureKestrel:
var?builder?=?WebApplication.CreateBuilder(args); builder.WebHost.ConfigureKestrel(options?=>?options.ListenLocalhost(5500,?opts?=>?opts.Protocols?=?HttpProtocols.Http1));6. WebApplication.Urls.Add 方法
.NET 6 版本
這是 .NET 6 下增加的新方法:
var?app?=?builder.Build(); app.Urls.Add("http://localhost:5600");7. appsettings.json 文件
可以在 appsettings.json 文件中設(shè)置 Kestrel 端口:
{"Kestrel":?{"Endpoints":?{"Https":?{"Url":?"https://*:5701"},"Http":?{"Url":?"http://*:5700"}}} }優(yōu)先級(jí)
通過(guò)將上述設(shè)置方式進(jìn)行組合,發(fā)現(xiàn)優(yōu)先級(jí)順序如下:
- WebApplicationBuilder.WebHost.ConfigureKestrel 方法 / appsettings.json 文件 (2者可同時(shí)起作用) 
- WebApplication.Urls.Add 方法 
- 命令行參數(shù) --urls 
- 環(huán)境變量 ASPNETCORE_URLS 
- applicationUrl 屬性 
- 默認(rèn)值 
結(jié)論
如果在同一臺(tái)機(jī)器上運(yùn)行多個(gè) ASP.NET Core 實(shí)例,使用默認(rèn)值肯定不合適。
由于 WebApplicationBuilder.WebHost.ConfigureKestrel/WebApplication.Urls.Add 方法不能被覆蓋,而環(huán)境變量 ASPNETCORE_URLS 容易造成全局影響。
建議:始終使用 appsettings.json 文件配置啟動(dòng)地址。
如果你覺得這篇文章對(duì)你有所啟發(fā),請(qǐng)關(guān)注我的個(gè)人公眾號(hào)”My IO“
總結(jié)
以上是生活随笔為你收集整理的ASP.NET Core启动地址配置方法及优先级顺序 | .NET 6 版本的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        - 上一篇: 叮,您有一份ML.NET 速查手册请查收
- 下一篇: Avalonia跨平台入门第七篇之Rad
