ASP.NET?Core?5.0中的Host.CreateDefaultBuilder执行过程解析 |
ASP.NET Core 5.0中的Host.CreateDefaultBuilder执行过程通过Rider调试的方式看了下ASP.NET Core 5.0的Web API默认项目,重点关注Host.CreateDefaultBuilder(args)中的执行过程,主要包括主机配置、应用程序配置、日志配置和依赖注入配置这4个部分 。由于水平和篇幅有限,先整体理解、建立框架,后面再逐步细化,对每个配置部分再详细拆解 一.创建默认主机Host.CreateDefaultBuilder1.创建主机构建器CreateHostBuilder(args)基于ASP.NET Core 5.0构建的Web API项目的Program.cs文件大家应该都很熟悉: public class Program { public static void Main(string[] args) { CreateHostBuilder(args).Build().Run(); } public static IHostBuilder CreateHostBuilder(string[] args) => Host.CreateDefaultBuilder(args) .ConfigureWebHostDefaults(webBuilder => { webBuilder.UseStartup<Startup>(); }); } 2.创建默认构建器Host.CreateDefaultBuilder(args)本文重点讲解下Host.CreateDefaultBuilder(args)的执行过程,Microsoft.Extensions.Hosting.Host是一个静态类,包含2个方法: public static IHostBuilder CreateDefaultBuilder() =>CreateDefaultBuilder(args: null); public static IHostBuilder CreateDefaultBuilder(string[] args); 上面的方法最终调用的还是下面的方法,下面的方法主要包括几个部分:主机配置ConfigureHostConfiguration,应用程序配置ConfigureAppConfiguration,日志配置ConfigureLogging,依赖注入配置UseDefaultServiceProvider 。 二.主机配置ConfigureHostConfiguration主机配置ConfigureHostConfiguration相关源码如下: builder.UseContentRoot(Directory.GetCurrentDirectory()); builder.ConfigureHostConfiguration(config => { config.AddEnvironmentVariables(prefix: "DOTNET_"); if (args != null) { config.AddCommandLine(args); } }); 1.内存配置源
2.环境变量配置源
3.命令行配置源最开始认为参数args为null,经过调试发现args的值string[0],并且 三.应用程序配置ConfigureAppConfiguration应用程序配置ConfigureAppConfiguration相关源码如下: builder.ConfigureAppConfiguration((hostingContext, config) => { IHostEnvironment env = hostingContext.HostingEnvironment; bool reloadOnChange = hostingContext.Configuration.GetValue("hostBuilder:reloadConfigOnChange", defaultValue: true); config.AddJsonFile("appsettings.json", optional: true, reloadOnChange: reloadOnChange).AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true, reloadOnChange: reloadOnChange); if (env.IsDevelopment() && !string.IsNullOrEmpty(env.ApplicationName)) { var appAssembly = Assembly.Load(new AssemblyName(env.ApplicationName)); if (appAssembly != null) { config.AddUserSecrets(appAssembly, optional: true); } } config.AddEnvironmentVariables(); if (args != null) { config.AddCommandLine(args); } }) 1.程序运行的主机环境hostingContext.HostingEnvironment表示运行程序的主机环境,比如开发环境或者生产环境 。IHostEnvironment接口的数据结构为: public interface IHostEnvironment { // Development string EnvironmentName { get; set; } // WebApplication3 string ApplicationName { get; set; } // D:SoftwareProjectC#ProgramWebApplication3WebApplication3 string ContentRootPath { get; set; } // PhysicalFileProvider IFileProvider ContentRootFileProvider { get; set; } } 2.加载json配置文件接下来就是通过AddJsonFile()来添加配置文件了,如下所示: 3.添加用户秘钥配置源
四.日志配置ConfigureLogging日志配置ConfigureLogging相关源码如下: .ConfigureLogging((hostingContext, logging) => { bool isWindows = RuntimeInformation.IsOSPlatform(OSPlatform.Windows); if (isWindows) { // Default the EventLogLoggerProvider to warning or above logging.AddFilter<EventLogLoggerProvider>(level => level >= LogLevel.Warning); } logging.AddConfiguration(hostingContext.Configuration.GetSection("Logging")); logging.AddConsole(); logging.AddDebug(); logging.AddEventSourceLogger(); if (isWindows) { // Add the EventLogLoggerProvider on windows machines logging.AddEventLog(); } logging.Configure(options => { options.ActivityTrackingOptions = ActivityTrackingOptions.SpanId | ActivityTrackingOptions.TraceId | ActivityTrackingOptions.ParentId; }); }) 1.Windows日志级别从上述代码中可以看到是 2.日志的配置ILoggerProvider不同的实现方式有: logging.AddConsole(); //将日志输出到控制台 logging.AddDebug(); //将日志输出到调试窗口 logging.AddEventSourceLogger(); logging.AddEventLog(); 说明:这一部分详细的日志分析可以参考[6] 。 3.ActivityTrackingOptionspublic enum ActivityTrackingOptions { None = 0, //No traces will be included in the log SpanId = 1, //The record will contain the Span identifier TraceId = 2, //The record will contain the tracking identifier ParentId = 4, //The record will contain the parent identifier TraceState = 8, //The record will contain the tracking status TraceFlags = 16, //The log will contain trace flags } 在最新的.NET 7 Preview6中又增加了Tags(32)和Baggage(64) 。 五.依赖注入配置UseDefaultServiceProvider依赖注入配置UseDefaultServiceProvider相关源码如下: .UseDefaultServiceProvider((context, options) => { bool isDevelopment = context.HostingEnvironment.IsDevelopment(); options.ValidateScopes = isDevelopment; options.ValidateOnBuild = isDevelopment; }); UseDefaultServiceProvider主要是设置默认的依赖注入容器 。 参考文献: 到此这篇关于ASP.NET Core 5.0中的Host.CreateDefaultBuilder执行过程解析的文章就介绍到这了,更多相关ASP.NET Core 5.0 Host.CreateDefaultBuilder执行过程内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持! |