欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ASP.NET?Core通用主機的系統(tǒng)配置

 更新時間:2022年07月08日 11:10:34   作者:天方  
這篇文章介紹了ASP.NET?Core通用主機系統(tǒng)配置的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

ASP.NET Core 2.0 中的 WebHost(實現(xiàn) IWebHost 的基類)是用于為進程提供 HTTP 服務器功能的基礎(chǔ)結(jié)構(gòu)項目,例如,如果正在實現(xiàn) MVC Web 應用或 Web API 服務。 它提供 ASP.NET Core 中所有新的基礎(chǔ)結(jié)構(gòu)優(yōu)點,使用戶能夠使用依賴關(guān)系注入,在請求管道中插入中間件等,并精確地將這些 IHostedServices 用于后臺任務。

.NET Core 2.1 中引入了 Host(實現(xiàn) IHost 的基類)。 它能讓用戶擁有與 WebHost相似的基礎(chǔ)結(jié)構(gòu),使用它我們可以獲取和Asp.net core一樣的框架功能(依賴項注入、日志、配置、托管服務等),如果我們編寫一個服務的時候,它提供了一個非常好用的框架。一個基本的示例代碼如下: 

public static async Task Main(string[] args)
{
    var host = new HostBuilder().Build();
    await host.RunAsync();
}

主要有如下兩個步驟

  • 通過HostBuilder生成一個Host

  • 指向Host的Run函數(shù)運行主機

前面的代碼只有一個空環(huán)境,要實現(xiàn)依賴項注入、日志、配置、托管服務等功能,還需要進一步的配置,本文的這里就簡單的介紹一下通用主機的配置方法。

系統(tǒng)配置

系統(tǒng)配置有兩個函數(shù)ConfigureHostConfiguration和ConfigureAppConfiguration 

hostBuilder.ConfigureHostConfiguration(configHost =>
{
    configHost.SetBasePath(Directory.GetCurrentDirectory());
    configHost.AddJsonFile("hostsettings.json", optional: true);
    configHost.AddEnvironmentVariables(prefix: "PREFIX_");
    configHost.AddCommandLine(args);
});

這兩個函數(shù)使用比較類似,它們的關(guān)系是主機配置用于初始化 IHostingEnvironment,以供在應用的構(gòu)建過程中使用。

依賴關(guān)系注入

通用主機集成了DI框架,如果要使用DI框架,則需要調(diào)用ConfigureServices函數(shù)極限依賴關(guān)系注入: 

hostBuilder.ConfigureServices((context, services) =>
{
    services.AddScoped<MyService>();
});

配置日志

我們可以通過在ConfigureServices中通過DI框架配置日志系統(tǒng),但HostBuilder單獨提供了一個配置日志的接口ConfigureLogging: 

hostBuilder.ConfigureLogging((hostContext, configLogging) =>
{
    configLogging.AddConsole();
    configLogging.AddDebug();
});

它內(nèi)部實際上依然是通過DI框架配置的日志系統(tǒng)。

通用配置

除了通過new一個HostBuilder外,系統(tǒng)還提供了一個創(chuàng)建HostBuilder的方法。

Host.CreateDefaultBuilder()

它的內(nèi)部也是調(diào)用HostBuilder的,但他提供了一般常用的選項,具體包括:

  • 將內(nèi)容根設(shè)置為由 Directory.GetCurrentDirectory 返回的路徑。

  • 通過以下對象加載主機配置:

  • 前綴為 DOTNET_ 的環(huán)境變量。(例如,DOTNET_ENVIRONMENT)。

  • 命令行參數(shù)。

  • 按以下順序加載應用配置:

    • appsettings.json。

    • appsettings.{Environment}.json。

    • 應用在使用入口程序集的 Development 環(huán)境中運行時的機密管理器。

    • 環(huán)境變量。

    • 命令行參數(shù)。

  • 配置控制臺和調(diào)試輸出的日志記錄。 日志記錄包含 appsettings.json 或 appsettings.{Environment}.json 文件的日志記錄配置部分中指定的日志篩選規(guī)則。

  • 如果應用環(huán)境為"開發(fā)",請將 ServiceProviderOptions.ValidateScopes 設(shè)為 true。 有關(guān)詳細信息,請參閱作用域驗證。

也就是說,它基本上提供了我們所常用的大部分功能,并且它返回的也是一個HostBuilder,我們還可以在它的基礎(chǔ)上接著配置,實現(xiàn)我們系統(tǒng)中的特有功能

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:

相關(guān)文章

最新評論