.Net Core日志记录器实例分析


这篇“.NetCore日志记录器实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“.NetCore日志记录器实例分析”文章吧。ILoggerFactory是日志记录器的工厂接口类,用于配置日志记录系统并创建Logger实例的类,默认实现两个接口方法为,通过CreateLogger()方法来创建ILogger实例,(其中参数categoryName是一个日志类别,用于调用Logger所在类的全名,类别指明日志消息是谁写入的,一般我们将日志所属的的组件、服务或者消息类型名称作为日志类别。) 而AddProvider()添加日志记录提供程序,向日志系统注册添加一个ILoggerProvider。工厂接口类的默认实现类为LoggerFactory, 我们继续往下看:ILoggerFactory的默认实现是LoggerFactory,在构造函数中,如下:从LoggerFactory中 的构造函数中可以发现,通过注入的方式获取到ILoggerProvider(这个在下文中会说明),并调用AddProviderRegistration方法添加注册程序,将ILoggerProvider保存到ProviderRegistration集合中。AddProviderRegistration方法:这是一个日志程序提供器,将ILoggerProvider保存到ProviderRegistration集合中。当日志提供器实现ISupportExternalScope接口将单例LoggerExternalScopeProvider保存到 provider._scopeProvider 中。ProviderRegistration集合:其中的ShouldDispose字段标识在在LoggerFactory生命周期结束之后,该ILoggerProvider是否需要释放。虽然在系统中LoggerFactory为单例模式,但是其提供了一个静态方法生成一个可释放的DisposingLoggerFactory。在LoggerFactory实现默认的接口方法CreateLogger(),AddProvider()查看源码如下:创建ILogger实例,CreateLogger()源码如下:从源码可以看出,CreateLogger方法中,会检测资源是否被释放,在方法中,根据内部定义的字典集合Dictionary _loggers,判断字典中是否存在对应的Logger属性对象,如果不存在,会调用CreateLoggers方法根据之前注册的的所有ILoggerProvider所创建出来ProviderRegistration集合来实现创建Logger属性集合(根据日志类别生成了对应实际的日志写入类FileLoggerConsoleLogger等),并通过字典集合的方式保存categoryName和对应的Logger。创建Logger需要的LoggerInformation[]根据注册的ILoggerProvider,创建ILogger其中的字段说明:Logger :具体日志类别写入途径实现类Category : 日志类别名称ProviderType : 日志提供器TypeExternalScope :是否支持 ExternalScope继续看CreateLogger方法,在创建Logger之后,还调用了ApplyFilters方法:由源码可以看出,MessageLogger[]集合取值:在获取LoggerInfor免费云主机域名mation[]后进行传参,进行遍历,根据RuleSelector过滤器,从配置文件中读取对应的日志级别,过滤器会返回获取最低级别和对应的一条过滤规则,如果配置文件中没有对应的配置,默认取全局最低级别(MinLevel),如果读取到的日志级别大于LogLevel.Critical,则将其加入MessageLogger[]。过滤器的规则:选择当前记录器类型的规则,如果没有,请选择未指定记录器类型的规则选择最长匹配类别的规则如果没有与类别匹配的内容,则采用所有没有类别的规则如果只有一条规则,则使用它的级别和过滤器如果有多个规则,请选择使用最后一条。如果没有适用的规则,请使用全局最低级别通过MessageLogger[]添加消息日志集合在MessageLogger[]中带有MinLevel属性和Filter委托两种过滤配置,而这两种配置的来源,在上一章中可以看到,分别是从配置文件(AddConfiguration)和直接使用委托(AddFilter)来进行配置的。再由上面的IsEnabled方法可以看出,会先使用MinLevel过滤,再使用Filter进行过滤。所以这两者存在优先级。ScopeLogger[ ]取值 :如果ILoggerProvider实现了ISupportExternalScope接口,那么使用LoggerExternalScopeProvider作为Scope功能的实现。反之,使用ILogger作为其Scope功能的实现。LoggerExternalScopeProvider:通过Scope组成了一个单向链表,每次beginscope向链表末端增加一个新的元素,Dispose的时候,删除链表最末端的元素。我们知道LoggerExternalScopeProvider在系统中是单例模式,多个请求进来,加入线程池处理。通过使用AsyncLoca来实现不同线程间数据独立。有两个地方开启了日志作用域:1、通过socket监听到请求后,将KestrelConnection加入线程池,线程池调度执行IThreadPoolWorkItem.Execute()方法。在这里开启了一次2、在构建请求上下文对象的时候(HostingApplication.CreateContext()),开启了一次由上源码可以得出:在工厂记录器类中,通过系统依赖注入的方式解析所有注册的ILoggerProvider,然后调用其中的CreateLogger方法实现创建一个Logger实例对象,而这个Logger实例对象会根据根据注册的ILoggerProvider创建需要的LoggerInformation[],并将此对象作为参数进行ApplyFilters过滤器筛选,得到对应的最低等级或过滤规则,最后通过调用Log方法日志记录的时候,会遍历MessageLogger[]集合,根据logger日志类别对应实际不同的日志写入类,调用ILoggerProvider具体实现类 (可以看下文说明) 中的Log方法。AddProviderRegistration→CreateLoggers→LoggerInformation[]→ApplyFilters→MessageLogger[]→Log→ILoggerProvider ( 执行具体类中的Log方法 )ILoggerFactory来源:应用程序在启动初始化的时候会通过注入的方式CreateDefaultBuilderConfigureLoggingAddLogging实现将把ILoggerFactory对象以依赖注入的方式托管到集合容器中,为程序调用提供使用。创建ILogger实例的类型,根据日志类别名称创建一个新的ILogger实例这个是具体的日志写入类,在工厂记录器中我们已经提到了这个,在LoggerInformation[]中会根据日志类别注册对应的ILoggerProvider,在系统中我们就可以通过ILogger同时向多个途经写入日志信息。(这也是对上一篇中留下的问题进行再次说明)ILoogerProvider继承了IDisposable接口,如果某个具体的ILoggerProvider对象需要释放资源,就可以将相关的操作实现在Dispose方法中。默认的实现方式为多个,官方实现的由ConsoleLoggerProviderDebugLoggerProviderEventSourceLoggerProviderEventLogLoggerProviderTraceSourceLoggerProviderConsoleLoggerProvider为列在ConsoleLoggerProvider类型定义中,标注了ProviderAliasAttribute特性,并设置别名为Console,所以在配置过滤规则的时候,可以直接使用这个名称。ILogger的创建实现了具体日志类ConsoleLogger。表示用于执行日志记录的类型,是系统中写入日志的统一入口。定义了三个方法,Log()用于写入日志,IsEnabled()用于检查判断日志级别是否开启,BeginScope()用于指日志作用域。ILogger执行记录接口类的具体实现Logger如下:源码中MessageLogger[]在上文已经提到了,其中保存了在配置中启用的那些对应的ILogger。需要注意的是,由于配置文件更改后,会调用ApplyFilters()方法,并为MessageLogger[]赋新值,所以在遍历之前,需要保存当前值,再进行处理。否则会出现修改异常。在系统中统一写入日志的入口,通过日志等级作为参数调用其IsEnabled方法来确定当前日志是否执行对应具体日志的实现类,当符合条件执行具体日志输出到对应的写入途径中会调用对应的Log方法(需要提供一个EventId来标识当前日志事件)ILogger默认的实现方式为多个,官方实现的由ConsoleLoggerDebugLoggerEventSourceLoggerEventLogLoggerTraceSourceLogger具体日志实现类代表不同的日志写入途径。以上就是关于“.NetCore日志记录器实例分析”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注百云主机行业资讯频道。

相关推荐: jquery赋值的方式有哪些

本篇内容介绍了“jquery赋值的方式有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! jquery有3种赋值方式:1、使用text(),语法“$(sele…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 03/13 12:57
下一篇 03/13 13:41

相关推荐