日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程语言 > asp.net >内容正文

asp.net

基于.NetCore3.1系列 —— 日志记录之日志核心要素揭秘

發(fā)布時(shí)間:2023/12/4 asp.net 71 豆豆
生活随笔 收集整理的這篇文章主要介紹了 基于.NetCore3.1系列 —— 日志记录之日志核心要素揭秘 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

前言

在上一篇中,我們已經(jīng)了解了內(nèi)置系統(tǒng)的默認(rèn)配置和自定義配置的方式,在學(xué)習(xí)了配置的基礎(chǔ)上,我們進(jìn)一步的對(duì)日志在程序中是如何使用的深入了解學(xué)習(xí)。所以在這一篇中,主要是對(duì)日志記錄的核心機(jī)制進(jìn)行學(xué)習(xí)說(shuō)明。

說(shuō)明

在上一篇中,我們留下了兩個(gè)問(wèn)題

  • 日志記錄的輸出可以在哪里查看?而又由什么實(shí)現(xiàn)決定的呢?

  • 如何管理輸出不同的日志呢?都有哪些方式呢?

  • 第一個(gè)問(wèn)題:在官方的實(shí)現(xiàn)有:Console 、Debug 、EventSource 、EventLog 、TraceSource 、Azure App Service,還有一些第三方實(shí)現(xiàn),當(dāng)然了我們自己也是可以實(shí)現(xiàn)的。是由ILoggerProvider接口來(lái)決定實(shí)現(xiàn)的。

    第二個(gè)問(wèn)題:由 log Level、EventId、Logger Provider、Log filtering、Log category、Log scopes 合作解決。

    由上面的問(wèn)題可以發(fā)現(xiàn),我們可以實(shí)現(xiàn)多種不同的輸出目標(biāo)方式來(lái)實(shí)現(xiàn)寫(xiě)日志記錄,但是又如何控制在寫(xiě)日志這個(gè)操作不變的情況下,實(shí)現(xiàn)不同的輸入目標(biāo),這個(gè)時(shí)候我們就會(huì)想到,可以通過(guò)抽象的方式,將寫(xiě)日志這個(gè)操作動(dòng)作抽象出來(lái),而輸出目標(biāo)依賴這個(gè)動(dòng)作實(shí)現(xiàn)具體的操作。所以當(dāng)我們調(diào)用寫(xiě)日志操作方法的時(shí)候,由此依次調(diào)用對(duì)應(yīng)的具體實(shí)現(xiàn)方法,把日志寫(xiě)到具體的目標(biāo)上。

    這個(gè)過(guò)程具體是怎么實(shí)現(xiàn)的呢?我們接著往下看。

    開(kāi)始

    其實(shí)在學(xué)習(xí)之前,我們應(yīng)該都已經(jīng)了解.net core框架有一個(gè)重要的特征就是依賴注入,通過(guò)在應(yīng)用啟動(dòng)時(shí)候,將各種定義好的實(shí)現(xiàn)類(lèi)型放入到一個(gè)集合容器中,通過(guò)在運(yùn)行時(shí),將從集合容器中取出放入對(duì)應(yīng)的類(lèi)型中。

    日志記錄的的實(shí)現(xiàn)方式也離不開(kāi)這個(gè)。下面讓我們一起來(lái)看看。

    日志記錄器工廠

    ?? 1. ILoggerFactory接口

    public interface ILoggerFactory : IDisposable {ILogger CreateLogger(string categoryName);void AddProvider(ILoggerProvider provider); }

    ILoggerFactory是日志記錄器的工廠接口類(lèi),用于配置日志記錄系統(tǒng)并創(chuàng)建Logger實(shí)例的類(lèi),默認(rèn)實(shí)現(xiàn)兩個(gè)接口方法為,通過(guò)CreateLogger()方法來(lái)創(chuàng)建ILogger實(shí)例,(其中參數(shù)categoryName是一個(gè)日志類(lèi)別,用于調(diào)用Logger所在類(lèi)的全名,類(lèi)別指明日志消息是誰(shuí)寫(xiě)入的,一般我們將日志所屬的的組件、服務(wù)或者消息類(lèi)型名稱作為日志類(lèi)別。) ?而AddProvider()添加日志記錄提供程序,向日志系統(tǒng)注冊(cè)添加一個(gè)ILoggerProvider。工廠接口類(lèi)的默認(rèn)實(shí)現(xiàn)類(lèi)為L(zhǎng)oggerFactory, 我們繼續(xù)往下看:

    2. LoggerFactory實(shí)現(xiàn)

    ILoggerFactory 的默認(rèn)實(shí)現(xiàn)是 LoggerFactory ,在構(gòu)造函數(shù)中,如下:

    ? ?public class LoggerFactory : ILoggerFactory{private static readonly LoggerRuleSelector RuleSelector = new LoggerRuleSelector();private readonly Dictionary<string, Logger> _loggers = new Dictionary<string, Logger>(StringComparer.Ordinal);private readonly List<ProviderRegistration> _providerRegistrations = new List<ProviderRegistration>();private readonly object _sync = new object();private volatile bool _disposed;private IDisposable _changeTokenRegistration;private LoggerFilterOptions _filterOptions;private LoggerExternalScopeProvider _scopeProvider;public LoggerFactory() : this(Enumerable.Empty<ILoggerProvider>()){}public LoggerFactory(IEnumerable<ILoggerProvider> providers) : this(providers, new StaticFilterOptionsMonitor(new LoggerFilterOptions())){}public LoggerFactory(IEnumerable<ILoggerProvider> providers, LoggerFilterOptions filterOptions) : this(providers, new StaticFilterOptionsMonitor(filterOptions)){}public LoggerFactory(IEnumerable<ILoggerProvider> providers, IOptionsMonitor<LoggerFilterOptions> filterOption){foreach (var provider in providers){AddProviderRegistration(provider, dispose: false);}_changeTokenRegistration = filterOption.OnChange(RefreshFilters);RefreshFilters(filterOption.CurrentValue);}private void AddProviderRegistration(ILoggerProvider provider, bool dispose){_providerRegistrations.Add(new ProviderRegistration{Provider = provider,ShouldDispose = dispose});if (provider is ISupportExternalScope supportsExternalScope){if (_scopeProvider == null){_scopeProvider = new LoggerExternalScopeProvider();}supportsExternalScope.SetScopeProvider(_scopeProvider);}}}

    從LoggerFactory 中 的構(gòu)造函數(shù)中可以發(fā)現(xiàn),通過(guò)注入的方式獲取到ILoggerProvider(這個(gè)在下文中會(huì)說(shuō)明),并調(diào)用AddProviderRegistration方法添加注冊(cè)程序,將ILoggerProvider保存到ProviderRegistration集合中。

    AddProviderRegistration 方法:

    這是一個(gè)日志程序提供器,將ILoggerProvider保存到ProviderRegistration集合中。當(dāng)日志提供器實(shí)現(xiàn) ISupportExternalScope 接口將單例 LoggerExternalScopeProvider 保存到 provider._scopeProvider 中。

    ProviderRegistration集合:

    private struct ProviderRegistration {public ILoggerProvider Provider;public bool ShouldDispose; }

    其中的 ShouldDispose 字段標(biāo)識(shí)在在LoggerFactory生命周期結(jié)束之后,該ILoggerProvider是否需要釋放。雖然在系統(tǒng)中LoggerFactory為單例模式,但是其提供了一個(gè)靜態(tài)方法生成一個(gè)可釋放的DisposingLoggerFactory。

    在LoggerFactory 實(shí)現(xiàn)默認(rèn)的接口方法CreateLogger(),AddProvider()

    查看源碼如下:

    CreateLogger

    創(chuàng)建ILogger實(shí)例,CreateLogger() 源碼如下:

    ? ?public class LoggerFactory : ILoggerFactory{private readonly Dictionary<string, Logger> _loggers = new Dictionary<string, Logger>(StringComparer.Ordinal);private readonly List<ProviderRegistration> _providerRegistrations = new List<ProviderRegistration>();private struct ProviderRegistration{public ILoggerProvider Provider;public bool ShouldDispose;}public ILogger CreateLogger(string categoryName){if (CheckDisposed()){throw new ObjectDisposedException(nameof(LoggerFactory));}lock (_sync){if (!_loggers.TryGetValue(categoryName, out var logger)){logger = new Logger{Loggers = CreateLoggers(categoryName),};(logger.MessageLoggers, logger.ScopeLoggers) = ApplyFilters(logger.Loggers);_loggers[categoryName] = logger;}return logger;}}private LoggerInformation[] CreateLoggers(string categoryName){var loggers = new LoggerInformation[_providerRegistrations.Count];for (var i = 0; i < _providerRegistrations.Count; i++){loggers[i] = new LoggerInformation(_providerRegistrations[i].Provider, categoryName);}return loggers;}}

    從源碼可以看出,CreateLogger方法中,會(huì)檢測(cè)資源是否被釋放,在方法中,根據(jù)內(nèi)部定義的字典集合Dictionary<string, Logger> _loggers,判斷字典中是否存在對(duì)應(yīng)的Logger屬性對(duì)象,如果不存在,會(huì)調(diào)用CreateLoggers方法根據(jù)之前注冊(cè)的的所有ILoggerProvider所創(chuàng)建出來(lái) ProviderRegistration 集合來(lái)實(shí)現(xiàn)創(chuàng)建Logger屬性集合(根據(jù)日志類(lèi)別生成了對(duì)應(yīng)實(shí)際的日志寫(xiě)入類(lèi)FileLogger、ConsoleLogger等),并通過(guò)字典集合的方式保存categoryName和對(duì)應(yīng)的Logger。

    創(chuàng)建 Logger 需要的 LoggerInformation[]

    internal readonly struct LoggerInformation { public LoggerInformation(ILoggerProvider provider, string category) : this() { ProviderType = provider.GetType(); Logger = provider.CreateLogger(category); Category = category; ExternalScope = provider is ISupportExternalScope; }public ILogger Logger { get; }public string Category { get; }public Type ProviderType { get; }public bool ExternalScope { get; } }

    根據(jù)注冊(cè)的ILoggerProvider,創(chuàng)建ILogger 其中的字段說(shuō)明:

    Logger :具體日志類(lèi)別寫(xiě)入途徑實(shí)現(xiàn)類(lèi)

    Category :日志類(lèi)別名稱

    ProviderType :日志提供器Type

    ExternalScope ?:是否支持 ExternalScope

    繼續(xù)看CreateLogger方法,在創(chuàng)建Logger之后,還調(diào)用了ApplyFilters方法:

    ? ? ? ?private (MessageLogger[] MessageLoggers, ScopeLogger[] ScopeLoggers) ApplyFilters(LoggerInformation[] loggers){var messageLoggers = new List<MessageLogger>();var scopeLoggers = _filterOptions.CaptureScopes ? new List<ScopeLogger>() : null;foreach (var loggerInformation in loggers){RuleSelector.Select(_filterOptions,loggerInformation.ProviderType,loggerInformation.Category,out var minLevel,out var filter);if (minLevel != null && minLevel > LogLevel.Critical){continue;}messageLoggers.Add(new MessageLogger(loggerInformation.Logger, loggerInformation.Category, loggerInformation.ProviderType.FullName, minLevel, filter));if (!loggerInformation.ExternalScope){scopeLoggers?.Add(new ScopeLogger(logger: loggerInformation.Logger, externalScopeProvider: null));}}if (_scopeProvider != null){scopeLoggers?.Add(new ScopeLogger(logger: null, externalScopeProvider: _scopeProvider));}return (messageLoggers.ToArray(), scopeLoggers?.ToArray());}

    由源碼可以看出,

    MessageLogger[] 集合取值:

    在獲取LoggerInformation[]后進(jìn)行傳參,進(jìn)行遍歷,根據(jù)RuleSelector過(guò)濾器,從配置文件中讀取對(duì)應(yīng)的日志級(jí)別,過(guò)濾器會(huì)返回獲取最低級(jí)別和對(duì)應(yīng)的一條過(guò)濾規(guī)則,如果配置文件中沒(méi)有對(duì)應(yīng)的配置,默認(rèn)取全局最低級(jí)別(MinLevel),如果讀取到的日志級(jí)別大于LogLevel.Critical,則將其加入MessageLogger[]。

    過(guò)濾器的規(guī)則:

  • 選擇當(dāng)前記錄器類(lèi)型的規(guī)則,如果沒(méi)有,請(qǐng)選擇未指定記錄器類(lèi)型的規(guī)則

  • 選擇最長(zhǎng)匹配類(lèi)別的規(guī)則

  • 如果沒(méi)有與類(lèi)別匹配的內(nèi)容,則采用所有沒(méi)有類(lèi)別的規(guī)則

  • 如果只有一條規(guī)則,則使用它的級(jí)別和過(guò)濾器

  • 如果有多個(gè)規(guī)則,請(qǐng)選擇使用最后一條。

  • 如果沒(méi)有適用的規(guī)則,請(qǐng)使用全局最低級(jí)別

  • 通過(guò)MessageLogger[]添加消息日志集合

    internal readonly struct MessageLogger {public MessageLogger(ILogger logger, string category, string providerTypeFullName, LogLevel? minLevel, Func<string, string, LogLevel, bool> filter){Logger = logger;Category = category;ProviderTypeFullName = providerTypeFullName;MinLevel = minLevel;Filter = filter;}public ILogger Logger { get; }public string Category { get; }private string ProviderTypeFullName { get; }public LogLevel? MinLevel { get; }public Func<string, string, LogLevel, bool> Filter { get; }public bool IsEnabled(LogLevel level){if (MinLevel != null && level < MinLevel){return false;}if (Filter != null){return Filter(ProviderTypeFullName, Category, level);}return true;} }internal readonly struct ScopeLogger {public ScopeLogger(ILogger logger, IExternalScopeProvider externalScopeProvider){Logger = logger;ExternalScopeProvider = externalScopeProvider;}public ILogger Logger { get; }public IExternalScopeProvider ExternalScopeProvider { get; }public IDisposable CreateScope<TState>(TState state){if (ExternalScopeProvider != null){return ExternalScopeProvider.Push(state);}return Logger.BeginScope<TState>(state);} }

    在MessageLogger[]中帶有MinLevel屬性和Filter委托兩種過(guò)濾配置,而這兩種配置的來(lái)源,在上一章中可以看到,分別是從配置文件(AddConfiguration)和直接使用委托(AddFilter)來(lái)進(jìn)行配置的。

    再由上面的IsEnabled方法可以看出,會(huì)先使用 MinLevel 過(guò)濾,再使用 Filter 進(jìn)行過(guò)濾。所以這兩者存在優(yōu)先級(jí)。

    ScopeLogger[ ] 取值 :

    如果 ILoggerProvider實(shí)現(xiàn)了ISupportExternalScope接口,那么使用LoggerExternalScopeProvider作為Scope功能的實(shí)現(xiàn)。反之,使用ILogger作為其Scope功能的實(shí)現(xiàn)。

    LoggerExternalScopeProvider ?:

    • 通過(guò) Scope 組成了一個(gè)單向鏈表,每次 beginscope 向鏈表末端增加一個(gè)新的元素,Dispose的時(shí)候,刪除鏈表最末端的元素。我們知道LoggerExternalScopeProvider 在系統(tǒng)中是單例模式,多個(gè)請(qǐng)求進(jìn)來(lái),加入線程池處理。通過(guò)使用AsyncLoca來(lái)實(shí)現(xiàn)不同線程間數(shù)據(jù)獨(dú)立。

    • 有兩個(gè)地方開(kāi)啟了日志作用域:

    • 1、通過(guò)socket監(jiān)聽(tīng)到請(qǐng)求后,將KestrelConnection加入線程池,線程池調(diào)度執(zhí)行IThreadPoolWorkItem.Execute()方法。在這里開(kāi)啟了一次

    • 2、在構(gòu)建請(qǐng)求上下文對(duì)象的時(shí)候(HostingApplication.CreateContext()),開(kāi)啟了一次

    由上源碼可以得出:在工廠記錄器類(lèi)中,通過(guò)系統(tǒng)依賴注入的方式解析所有注冊(cè)的ILoggerProvider,然后調(diào)用其中的CreateLogger方法實(shí)現(xiàn)創(chuàng)建一個(gè)Logger實(shí)例對(duì)象,而這個(gè)Logger實(shí)例對(duì)象會(huì)根據(jù)根據(jù)注冊(cè)的ILoggerProvider創(chuàng)建需要的LoggerInformation[],并將此對(duì)象作為參數(shù)進(jìn)行ApplyFilters過(guò)濾器篩選,得到對(duì)應(yīng)的最低等級(jí)或過(guò)濾規(guī)則,最后通過(guò)調(diào)用Log方法日志記錄的時(shí)候,會(huì)遍歷MessageLogger[]集合,根據(jù)logger日志類(lèi)別對(duì)應(yīng)實(shí)際不同的日志寫(xiě)入類(lèi),調(diào)用ILoggerProvider具體實(shí)現(xiàn)類(lèi) (可以看下文說(shuō)明) 中的Log方法。? ?

    AddProviderRegistration→CreateLoggers→LoggerInformation[]→ApplyFilters→MessageLogger[]→Log→ILoggerProvider ( 執(zhí)行具體類(lèi)中的Log方法 )

    ILoggerFactory 來(lái)源

    在上一篇中我們?cè)趯?duì)日志配置進(jìn)行說(shuō)明的時(shí)候,應(yīng)用程序在啟動(dòng)初始化的時(shí)候會(huì)通過(guò)注入的方式CreateDefaultBuilder→ConfigureLogging→AddLogging

    public static IServiceCollection AddLogging(this IServiceCollection services, Action<ILoggingBuilder> configure) { if (services == null) {throw new ArgumentNullException(nameof(services)); }services.AddOptions(); services.TryAdd(ServiceDescriptor.Singleton<ILoggerFactory, LoggerFactory>()); services.TryAdd(ServiceDescriptor.Singleton(typeof(ILogger<>), typeof(Logger<>)));services.TryAddEnumerable(ServiceDescriptor.Singleton<IConfigureOptions<LoggerFilterOptions>>(new DefaultLoggerLevelConfigureOptions(LogLevel.Information)));configure(new LoggingBuilder(services)); return services; }

    實(shí)現(xiàn)將把ILoggerFactory對(duì)象以依賴注入的方式托管到集合容器中,為程序調(diào)用提供使用。

    日志記錄提供器

    ? 1. ILoggerProvider 接口

    創(chuàng)建ILogger實(shí)例的類(lèi)型,根據(jù)日志類(lèi)別名稱創(chuàng)建一個(gè)新的ILogger實(shí)例

    public interface ILoggerProvider : IDisposable {ILogger CreateLogger(string categoryName); }

    這個(gè)是具體的日志寫(xiě)入類(lèi),在工廠記錄器中我們已經(jīng)提到了這個(gè),在LoggerInformation[]中會(huì)根據(jù)日志類(lèi)別注冊(cè)對(duì)應(yīng)的ILoggerProvider,在系統(tǒng)中我們就可以通過(guò)ILogger同時(shí)向多個(gè)途經(jīng)寫(xiě)入日志信息。(這也是對(duì)上一篇中留下的問(wèn)題進(jìn)行再次說(shuō)明)

    ILoogerProvider繼承了IDisposable接口,如果某個(gè)具體的ILoggerProvider對(duì)象需要釋放資源,就可以將相關(guān)的操作實(shí)現(xiàn)在Dispose方法中。

    默認(rèn)的實(shí)現(xiàn)方式為多個(gè),官方實(shí)現(xiàn)的由ConsoleLoggerProvider 、DebugLoggerProvider 、EventSourceLoggerProvider、EventLogLoggerProvider、TraceSourceLoggerProvider

    以ConsoleLoggerProvider為列

    ? [ProviderAlias("Console")]public class ConsoleLoggerProvider : ILoggerProvider, ISupportExternalScope{private readonly IOptionsMonitor<ConsoleLoggerOptions> _options;private readonly ConcurrentDictionary<string, ConsoleLogger> _loggers;private readonly ConsoleLoggerProcessor _messageQueue;private IDisposable _optionsReloadToken;private IExternalScopeProvider _scopeProvider = NullExternalScopeProvider.Instance;public ConsoleLoggerProvider(IOptionsMonitor<ConsoleLoggerOptions> options){_options = options;_loggers = new ConcurrentDictionary<string, ConsoleLogger>();ReloadLoggerOptions(options.CurrentValue);_optionsReloadToken = _options.OnChange(ReloadLoggerOptions);_messageQueue = new ConsoleLoggerProcessor();if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows)){_messageQueue.Console = new WindowsLogConsole();_messageQueue.ErrorConsole = new WindowsLogConsole(stdErr: true);}else{_messageQueue.Console = new AnsiLogConsole(new AnsiSystemConsole());_messageQueue.ErrorConsole = new AnsiLogConsole(new AnsiSystemConsole(stdErr: true));}}private void ReloadLoggerOptions(ConsoleLoggerOptions options){foreach (var logger in _loggers){logger.Value.Options = options;}}public ILogger CreateLogger(string name){return _loggers.GetOrAdd(name, loggerName => new ConsoleLogger(name, _messageQueue){Options = _options.CurrentValue,ScopeProvider = _scopeProvider});}public void Dispose(){_optionsReloadToken?.Dispose();_messageQueue.Dispose();}public void SetScopeProvider(IExternalScopeProvider scopeProvider){_scopeProvider = scopeProvider;foreach (var logger in _loggers){logger.Value.ScopeProvider = _scopeProvider;}}}

    在ConsoleLoggerProvider類(lèi)型定義中,標(biāo)注了ProviderAliasAttribute特性,并設(shè)置別名為Console,所以在配置過(guò)濾規(guī)則的時(shí)候,可以直接使用這個(gè)名稱。ILogger的創(chuàng)建實(shí)現(xiàn)了具體日志類(lèi)ConsoleLogger。

    日志記錄器

    ? ? ?1. ILogger接口

    表示用于執(zhí)行日志記錄的類(lèi)型,是系統(tǒng)中寫(xiě)入日志的統(tǒng)一入口。

    public interface ILogger {void Log<TState>(LogLevel logLevel, EventId eventId, TState state, Exception exception, Func<TState, Exception, string> formatter);bool IsEnabled(LogLevel logLevel);IDisposable BeginScope<TState>(TState state); }

    定義了三個(gè)方法,Log<TState>() 用于寫(xiě)入日志,IsEnabled()用于檢查判斷日志級(jí)別是否開(kāi)啟,BeginScope() 用于指日志作用域。

    2. Logger實(shí)現(xiàn)

    ILogger執(zhí)行記錄接口類(lèi)的具體實(shí)現(xiàn)Logger如下:

    internal class Logger : ILogger {public LoggerInformation[] Loggers { get; set; }public MessageLogger[] MessageLoggers { get; set; }public ScopeLogger[] ScopeLoggers { get; set; }public void Log<TState>(LogLevel logLevel, EventId eventId, TState state, Exception exception, Func<TState, Exception, string> formatter){var loggers = MessageLoggers;if (loggers == null){return;}List<Exception> exceptions = null;for (var i = 0; i < loggers.Length; i++){ref readonly var loggerInfo = ref loggers[i];if (!loggerInfo.IsEnabled(logLevel)){continue;}LoggerLog(logLevel, eventId, loggerInfo.Logger, exception, formatter, ref exceptions, state);}if (exceptions != null && exceptions.Count > 0){ThrowLoggingError(exceptions);}static void LoggerLog(LogLevel logLevel, EventId eventId, ILogger logger, Exception exception, Func<TState, Exception, string> formatter, ref List<Exception> exceptions, in TState state){try{logger.Log(logLevel, eventId, state, exception, formatter);}catch (Exception ex){if (exceptions == null){exceptions = new List<Exception>();}exceptions.Add(ex);}}}public bool IsEnabled(LogLevel logLevel){var loggers = MessageLoggers;if (loggers == null){return false;}List<Exception> exceptions = null;var i = 0;for (; i < loggers.Length; i++){ref readonly var loggerInfo = ref loggers[i];if (!loggerInfo.IsEnabled(logLevel)){continue;}if (LoggerIsEnabled(logLevel, loggerInfo.Logger, ref exceptions)){break;}}if (exceptions != null && exceptions.Count > 0){ThrowLoggingError(exceptions);}return i < loggers.Length ? true : false;static bool LoggerIsEnabled(LogLevel logLevel, ILogger logger, ref List<Exception> exceptions){try{if (logger.IsEnabled(logLevel)){return true;}}catch (Exception ex){if (exceptions == null){exceptions = new List<Exception>();}exceptions.Add(ex);}return false;}} }

    源碼中MessageLogger[]在上文已經(jīng)提到了,其中保存了在配置中啟用的那些對(duì)應(yīng)的ILogger。

    需要注意的是,由于配置文件更改后,會(huì)調(diào)用ApplyFilters()方法,并為MessageLogger[]賦新值,所以在遍歷之前,需要保存當(dāng)前值,再進(jìn)行處理。否則會(huì)出現(xiàn)修改異常。

    在系統(tǒng)中統(tǒng)一寫(xiě)入日志的入口,通過(guò)日志等級(jí)作為參數(shù)調(diào)用其IsEnabled方法來(lái)確定當(dāng)前日志是否執(zhí)行對(duì)應(yīng)具體日志的實(shí)現(xiàn)類(lèi),當(dāng)符合條件執(zhí)行具體日志輸出到對(duì)應(yīng)的寫(xiě)入途徑中會(huì)調(diào)用對(duì)應(yīng)的Log方法(需要提供一個(gè)EventId來(lái)標(biāo)識(shí)當(dāng)前日志事件)

    ILogger默認(rèn)的實(shí)現(xiàn)方式為多個(gè),官方實(shí)現(xiàn)的由ConsoleLogger 、DebugLogger 、EventSourceLogger、EventLogLogger、TraceSourceLogger 具體日志實(shí)現(xiàn)類(lèi)代表不同的日志寫(xiě)入途徑。

    總結(jié)

    ? ?1. 在ILoggerFactory和ILoggerProvider中都會(huì)通過(guò)方法創(chuàng)建ILogger對(duì)象,但兩者是不相同的。在工廠默認(rèn)實(shí)現(xiàn)LoggerFactory類(lèi)型中它創(chuàng)建的ILogger對(duì)象是由注冊(cè)到LoggerFactory對(duì)象上的所有ILoggerProvider對(duì)象提供一組 ILogger對(duì)象組合而成。而日志提供器ILoggerProvider創(chuàng)建的ILogger是日志實(shí)現(xiàn)輸出到對(duì)應(yīng)的渠道目標(biāo),寫(xiě)入日志。

    ? ?2. 日志記錄器ILogger中的Log()方法會(huì)記錄執(zhí)行日志,在日志記錄器工廠ILoggerFactory和日志記錄提供器ILoggerProvider中兩種不同的ILogger實(shí)現(xiàn)對(duì)應(yīng)的Log()方法實(shí)現(xiàn)的意思也是不同的。在ILoggerFactory產(chǎn)生的是ILogger類(lèi)型(也就是我們最終使用的Logger),其Log()方法是依次調(diào)用Logger中包含的LoggerInformation[]數(shù)組中的ILogger。而ILoggerProvider產(chǎn)生的為各類(lèi)不同的XxxLogger(也就是上面說(shuō)的Logger中的LoggerInformation數(shù)組包含的如ConsoleLogger、DebugLogger),其Log()方法是把日志寫(xiě)到具體的目標(biāo)上去。

    ? ?3. 由上文可以發(fā)現(xiàn),在asp.net core提供的日志記錄的組件,通過(guò)工廠的一種方式,將日志記錄器和日志記錄提供器都放入到工廠這樣的容器中,滿足定義多個(gè)不同的記錄方式。在后續(xù)我們可以通過(guò)自定義ILoggerProvider集成到Logger中,實(shí)現(xiàn)自己需要的日志記錄輸出方式。

    ? ? 4. 如果有不對(duì)的或不理解的地方,希望大家可以多多指正,提出問(wèn)題,一起討論,不斷學(xué)習(xí),共同進(jìn)步。

    ? ?5. 推薦搜索關(guān)注公眾號(hào) --【DotNet技術(shù)谷】

    總結(jié)

    以上是生活随笔為你收集整理的基于.NetCore3.1系列 —— 日志记录之日志核心要素揭秘的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

    91视频在线观看下载 | 69av国产| 亚欧日韩av | 天天摸日日操 | www.玖玖玖| 91成人黄色 | 又黄又刺激的视频 | 久久免费看av | 亚洲一级二级 | 日本少妇高清做爰视频 | 97在线精品 | 国产精品女人久久久 | 色射色 | 人人狠狠综合久久亚洲 | 久久av一区二区三区亚洲 | 一区二区三区 亚洲 | 中文亚洲欧美日韩 | 中文视频一区二区 | 亚洲欧美日韩国产一区二区 | 久久久久久久久久久久久影院 | 干天天| 欧美日本中文字幕 | 国产免费观看av | 久久不卡av| 深爱五月激情网 | 福利网址在线观看 | 午夜精品剧场 | 中文字幕免费高清在线观看 | 超碰.com| 欧美国产一区在线 | 99久热在线精品视频成人一区 | 日韩av成人在线观看 | 视频国产 | 奇米网8888 | 国产精品欧美日韩在线观看 | 久久久国产精品免费 | 久久久私人影院 | av中文国产| 婷婷中文字幕综合 | 久久久精品午夜 | 韩国一区在线 | 五月天中文字幕mv在线 | 亚洲成人av电影 | 国产一区网 | 亚洲精品视频第一页 | 久久久999免费视频 日韩网站在线 | 亚洲黄网站 | 免费看一级黄色大全 | 亚洲午夜精品久久久久久久久 | 91在线视频免费91 | 中文字幕在线看视频国产 | 国产精品高潮呻吟久久久久 | 亚洲精品成人网 | 五月婷婷国产 | 国产福利一区二区在线 | 久久99精品国产99久久6尤 | 精品99在线视频 | 欧美日韩免费在线视频 | 国产在线观看黄 | aaa日本高清在线播放免费观看 | 人人添人人 | 日本三级在线观看中文字 | 夜夜骑首页 | 色婷婷综合成人av | 在线观看亚洲视频 | 国产精品美女久久久久久免费 | 久久久久久久久久久久亚洲 | 天天曰视频 | 国产在线更新 | 99久久爱| 精品久久1 | 日韩丝袜 | 2019中文字幕第一页 | 久草在线视频看看 | 免费一级特黄录像 | 久久久高清免费视频 | 日韩高清一 | 日韩黄色免费电影 | 人人躁 | 91免费在线| 97精品国产97久久久久久免费 | 欧美福利精品 | 国产白浆视频 | 高清一区二区三区av | 中文字幕色在线 | 99精品国产高清在线观看 | 国产精品久久久久婷婷 | 丁香花在线视频观看免费 | 日韩在线观看a | 色搞搞| 久久国产色 | 国产精品综合av一区二区国产馆 | 国产最新视频在线 | 精品99免费| 国产一级在线看 | 日本超碰在线 | 中文字幕91在线 | 亚洲一区二区三区四区在线视频 | 日韩在线观看你懂的 | 婷婷久久五月天 | av在线免费观看黄 | 91在线porny国产在线看 | 国产精品初高中精品久久 | 亚洲国产精品电影在线观看 | 麻豆国产精品va在线观看不卡 | 日韩有码在线播放 | 中文字幕日韩一区二区三区不卡 | 久草视频免费播放 | 久久婷婷久久 | 在线观看视频国产 | 91av精品 | 欧洲成人免费 | 午夜国产福利在线 | a级片网站 | 四虎永久精品在线 | 久久久这里有精品 | 欧美性色xo影院 | 四虎国产精品免费观看视频优播 | 久久久99国产精品免费 | 91久久国产综合精品女同国语 | 我要看黄色一级片 | 免费观看日韩 | 日韩在线电影一区 | 97看片| 又黄又爽又湿又无遮挡的在线视频 | 欧美日韩在线观看一区二区 | 中文字幕高清 | 99精品区| 婷婷色中文| 久久精品久久精品 | 97av精品| 欧美老女人xx | 狠狠色狠狠色综合日日92 | 2018亚洲男人天堂 | 国产主播大尺度精品福利免费 | 四虎影视av | 国产婷婷精品av在线 | 伊人天天色 | 狠狠操狠狠干2017 | 久久精品99国产精品酒店日本 | 久久久污| 99精品亚洲 | 国产精品久久久久久久久费观看 | 91av电影在线观看 | 不卡的av在线 | wwwwww黄| 久久免费视频一区 | 久久免费视频这里只有精品 | 日韩免费一区二区在线观看 | 国产免费中文字幕 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 91麻豆精品国产91久久久久久 | 三级黄色理论片 | free. 性欧美.com | 国产精品日韩在线观看 | 999成人免费视频 | 国产精品免费小视频 | 国产手机在线播放 | 国产婷婷精品av在线 | 免费在线观看成人小视频 | 久久人人爽人人 | 激情综合五月天 | 国产剧情一区二区在线观看 | 伊人午夜视频 | 手机在线欧美 | 日韩欧美电影 | h动漫中文字幕 | 日日噜噜噜噜夜夜爽亚洲精品 | 麻豆免费视频观看 | 中字幕视频在线永久在线观看免费 | 一区 二区 精品 | 色老板在线视频 | 亚洲精品国产品国语在线 | 免费韩国av| 日本精品久久久久中文字幕 | 国产日韩欧美在线影视 | 午夜精品久久一牛影视 | 五月天激情婷婷 | 狠狠躁天天躁综合网 | 精品一二区 | 国产一区二区三区高清播放 | 欧美成人黄色片 | 黄色一级大片免费看 | 亚洲人成在线电影 | 青青河边草观看完整版高清 | 欧美日韩高清一区二区 | 国产资源精品在线观看 | 亚洲天堂va | 狠狠久久 | av色网站| 日日干夜夜骑 | 91亚洲精品久久久中文字幕 | 亚洲国产精品成人综合 | 国产精品99久久久精品 | 五月天婷亚洲天综合网精品偷 | 亚洲激情小视频 | 极品美女被弄高潮视频网站 | 国产精品大片免费观看 | 五月天高清欧美mv | 91激情 | 国产精品久久久久久久电影 | 日韩毛片在线一区二区毛片 | 婷婷四房综合激情五月 | 久久久久久毛片 | 亚洲黄色影院 | 日本黄色片一区二区 | 可以免费观看的av片 | 国产欧美日韩一区 | 蜜臀久久99精品久久久无需会员 | 国产精品免费小视频 | 国产视频第二页 | 国产中文字幕视频在线观看 | 日本一区二区不卡高清 | 91在线看黄 | 色偷偷人人澡久久超碰69 | 99久热| 中文电影网 | 欧美精品乱码99久久影院 | 五月婷婷六月丁香 | 九九电影在线 | 国产亚洲精品久久久网站好莱 | av资源在线看 | 又黄又刺激又爽的视频 | 免费看的黄网站软件 | 狠狠狠色丁香婷婷综合久久五月 | 婷婷婷国产在线视频 | 亚洲天堂色婷婷 | 97视频免费看| 视频二区在线 | 亚洲一级片在线观看 | 97精品国产手机 | 又色又爽又黄 | 999视频在线播放 | 欧美片一区二区三区 | 免费美女av | 91精品国自产拍天天拍 | 国产精久久 | 国产成人一区二区三区影院在线 | 最新免费中文字幕 | 99 色 | 久久久国产电影 | 久久精品牌麻豆国产大山 | 亚洲婷婷在线 | 毛片网站免费在线观看 | 欧美日韩精品在线免费观看 | 成人91av| 成人h电影在线观看 | 色婷婷精品大在线视频 | 久久久www成人免费毛片 | 国产高清视频 | 黄色一二级片 | 成人免费在线观看电影 | 日本公妇色中文字幕 | 一本一道久久a久久精品 | 成人免费视频播放 | 欧美日韩午夜 | 亚洲一本视频 | 美女网站在线观看 | 日韩在线视 | 黄色精品一区 | 亚洲精品视频免费 | .国产精品成人自产拍在线观看6 | 国产在线观看免 | 亚洲精品999 | 一区二区 不卡 | 国产二区免费视频 | 成人avav| 亚洲欧美日韩不卡 | 天天操天 | 日韩高清成人在线 | 亚洲人视频在线 | 国产精品国产亚洲精品看不卡15 | 色综合亚洲精品激情狠狠 | 五月婷婷丁香 | 亚洲自拍av在线 | 男女精品久久 | а天堂中文最新一区二区三区 | 最近中文字幕国语免费av | av电影一区二区三区 | 人人搞人人搞 | 日韩在线观看视频在线 | 天天爱天天插 | 射九九 | 国产视频精品久久 | 免费日韩 精品中文字幕视频在线 | 成人一区二区三区中文字幕 | 88av网站| 99视频导航| 97视频在线观看视频免费视频 | 三级黄色三级 | 成人精品福利 | 性色av免费在线观看 | 亚洲黄色在线免费观看 | 黄网站免费久久 | 午夜久久久久 | 成人免费中文字幕 | 欧美日韩精品在线视频 | 欧美大片在线观看一区 | 在线看片日韩 | 国产传媒中文字幕 | 国产区精品区 | 国产三级精品在线 | 日韩mv欧美mv国产精品 | 日韩av网站在线播放 | www久久 | 一区二区毛片 | 国产色综合天天综合网 | 国产69久久精品成人看 | 日韩性xxxx| 999视频在线观看 | 四虎在线免费视频 | 成人av免费在线播放 | 成人av电影网址 | 久久国产视频网站 | 91在线免费播放视频 | 成人资源站 | 欧美日韩亚洲第一页 | 玖草影院 | 国产成人一区二 | 日韩精品资源 | 91成人免费 | 日韩精品一区在线播放 | 天天色综合三 | 久日视频| 免费在线观看不卡av | 91亚洲精品乱码久久久久久蜜桃 | 中文字幕一二三区 | 激情综合久久 | 欧美精品久久久久久久免费 | 成人毛片网 | 日韩av中文字幕在线 | 天堂网一区 | 久久精品国产一区二区电影 | 国产99久久久国产精品 | 日韩理论 | 亚洲人成网站精品片在线观看 | 国产黄色网| 国产精品高潮在线观看 | www.在线观看视频 | 国产激情电影综合在线看 | 黄色福利视频网站 | 综合在线亚洲 | 黄色网在线免费观看 | 经典三级一区 | 欧洲一区二区在线观看 | 国产在线欧美 | 久久av免费观看 | av天天干 | 久久精品看 | 一区二区三区在线观看 | 久久这里只有精品23 | 久草视频一区 | 久久婷婷精品 | 91成人免费看片 | 丁香六月伊人 | 免费在线一区二区 | 亚洲狠狠操 | 亚洲 中文 在线 精品 | 国产成人在线免费观看 | 国产精品免费久久 | av专区在线 | 国产精品 日韩 欧美 | 亚洲午夜精品久久久 | 五月天久久综合网 | 久久久久久毛片精品免费不卡 | 亚洲激精日韩激精欧美精品 | 国产中文字幕国产 | 国产在线观看99 | 亚洲春色综合另类校园电影 | 深夜精品福利 | 五月婷婷丁香六月 | av手机在线播放 | 日本aa在线 | 深爱激情五月网 | 国产一级免费视频 | 国产精品久久久久久久久蜜臀 | 午夜精品久久久久久久99 | 国产亚洲精品美女久久 | 超碰国产人人 | 日本成人免费在线观看 | 黄色软件网站在线观看 | 国产亚洲视频在线观看 | 欧美性大战 | 天天躁天天躁天天躁婷 | 亚洲免费不卡 | 国产精品久久久久久久av大片 | 99热精品免费观看 | 人成电影网 | 欧美精品被 | 欧美日韩中文国产一区发布 | 91av手机在线观看 | 国产精品99久久久久 | 99这里只有精品视频 | 欧美亚洲精品在线观看 | 欧美一区二区三区不卡 | 日韩精品免费一区二区 | www.亚洲精品视频 | 国产午夜精品一区二区三区在线观看 | 午夜影院在线观看18 | 中文字幕一区二区三区四区视频 | 91av在线视频免费观看 | 久久精品福利视频 | 中文免费在线观看 | 91高清一区 | 日韩视频免费观看高清 | 欧美日韩伦理在线 | 日本在线观看视频一区 | 国产精品一级在线 | 日日综合| 在线免费av电影 | 国产精品久久久久久久久久久免费看 | 日韩理论影院 | 综合精品久久 | 国产成人精品区 | 午夜视频在线观看一区二区三区 | 久久久久久久福利 | 国产成人av在线影院 | 亚洲综合精品在线 | www.com操| 在线视频 影院 | 午夜精品婷婷 | 久久久国产精品久久久 | 欧美一级视频免费 | 操碰av | 欧美一级片播放 | 精品国产精品一区二区夜夜嗨 | 插综合网| 国产精品久久久久久久久久ktv | 国产成人精品亚洲a | 在线观看av中文字幕 | 国产一级在线免费观看 | 日韩欧美在线影院 | 亚洲精品国产精品久久99 | 伊人婷婷激情 | 国产老太婆免费交性大片 | 欧美日韩一区三区 | 亚洲最新在线 | 91久久丝袜国产露脸动漫 | 成人试看120秒 | 狠狠色丁香婷婷综合基地 | 美女免费视频黄 | 看国产黄色片 | 丁香花在线视频观看免费 | 亚洲一二三久久 | 色婷婷a | 久草在线视频精品 | 国产在线精品区 | 天天操天天草 | 日韩免费视频观看 | av福利在线播放 | 久久久久久久看片 | 欧美日韩视频在线观看一区二区 | 久久久久久网站 | 亚洲免费在线视频 | 99精品欧美一区二区三区 | 天天干天天碰 | 天天综合网入口 | 日韩精品一区二区三区外面 | 1024手机看片国产 | 97色婷婷成人综合在线观看 | 天天操综 | a极黄色片 | 99婷婷狠狠成为人免费视频 | 色婷婷视频在线 | 97超级碰碰碰碰久久久久 | 天天拍天天爽 | 8x成人免费视频 | 99久久精品免费一区 | 欧美成人xxxxxxxx | 97视频免费在线观看 | 欧美极品少妇xbxb性爽爽视频 | 麻豆视频免费入口 | 国产九九九精品视频 | 亚洲欧美精品一区 | 久久精品视频网站 | 日韩国产精品一区 | 狠狠色香婷婷久久亚洲精品 | 麻豆精品传媒视频 | 国产综合91 | 五月天综合激情网 | 日韩免费视频线观看 | 免费午夜视频在线观看 | 超碰97久久 | 免费看的国产视频网站 | 国产精品国产亚洲精品看不卡15 | 日日干激情五月 | 九九交易行官网 | 国产a级精品 | 久久久久 免费视频 | 亚洲一区二区三区毛片 | www.天堂av| 九热在线 | 欧美精品天堂 | 91大神精品视频在线观看 | 黄色av电影网 | 久99久精品视频免费观看 | 91在线小视频| 西西444www大胆高清视频 | 成人在线视频网 | av日韩av| 人人玩人人添人人澡97 | 亚洲成人家庭影院 | 久久综合久久综合久久综合 | www.激情五月.com | 国产精品久久久久久久久久久久午夜片 | 99中文在线 | 五月婷网站| 国产不卡视频在线 | 91精品少妇偷拍99 | av不卡免费看 | 午夜视频在线观看一区二区三区 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 日韩欧美视频 | 日本精品视频网站 | 国产精品久久久久久久久久东京 | 色综合在 | 色婷婷九月 | 夜夜躁狠狠躁日日躁视频黑人 | 欧洲激情综合 | 久久久久国产视频 | 综合久久精品 | 色综合色综合久久综合频道88 | 欧美视频一区二 | 欧美成人在线网站 | 久久久毛片 | 中文在线中文a | 99久久久久久久 | 久艹视频免费观看 | 亚洲电影网站 | 国产日韩欧美在线 | 在线视频你懂得 | 四虎成人精品 | 色网址99| 久久久久国 | 91资源在线视频 | 日韩爱爱网站 | 尤物一区二区三区 | 久久99热这里只有精品国产 | 久久人人爽人人爽 | 日韩av一区二区在线 | 在线电影中文字幕 | 日本中文一级片 | 色播五月激情综合网 | 精品一二区 | 五月开心婷婷网 | 六月婷婷久香在线视频 | 婷婷在线精品视频 | 日韩高清一区 | 男女拍拍免费视频 | 亚洲国产成人精品电影在线观看 | 国产精品久久久亚洲 | 久久99久久99精品中文字幕 | 超碰97人人在线 | 97久久精品午夜一区二区 | 九九精品毛片 | 午夜国产福利在线观看 | 91尤物国产尤物福利在线播放 | 狠狠色丁香久久综合网 | 麻豆传媒视频在线免费观看 | 色五婷婷 | 欧美日韩在线观看一区二区三区 | 国产精品免费在线观看视频 | 少妇18xxxx性xxxx片 | 亚洲精品成人网 | 亚洲国产中文字幕在线观看 | 日本中文字幕网站 | 免费看毛片网站 | av大全在线看 | 国产午夜精品av一区二区 | 亚洲精品国产麻豆 | 黄色www在线观看 | 成人网在线免费视频 | 黄色一级在线观看 | 91精品久久久久久久久久久久久 | 精品五月天 | 99热精品在线观看 | 精品久久久久久久久亚洲 | 欧洲视频一区 | 国产韩国精品一区二区三区 | 免费观看国产精品 | 亚洲国产伊人 | 国产剧情在线一区 | 国产高清区| 国产破处在线播放 | 综合天天久久 | 亚洲综合激情小说 | 成年人黄色大片在线 | 色噜噜狠狠色综合中国 | 欧美日韩中文国产 | 久久久久观看 | 国产精品一区免费观看 | 免费影视大全推荐 | 在线观看网站黄 | 天天干干| 久久精品超碰 | 国产剧情一区在线 | 青青河边草免费直播 | 美女网站视频久久 | 国产情侣一区 | 欧美在线你懂的 | 三级视频日韩 | 日韩欧美一区二区三区免费观看 | 亚洲精品视频免费观看 | 99这里只有久久精品视频 | 91在线视频网址 | 狠狠干天天操 | 日韩精品高清视频 | 亚洲天堂香蕉 | a黄色一级片 | 国产精品高清免费在线观看 | 狠狠的操狠狠的干 | 成人毛片久久 | 美女久久久久久久 | 婷婷精品国产一区二区三区日韩 | 国产69久久久欧美一级 | 97超碰在线久草超碰在线观看 | av电影免费| 国产精品不卡在线播放 | 欧美一级片在线观看视频 | 国产色拍拍拍拍在线精品 | 国产色在线视频 | 欧美特一级片 | 欧美日韩中文字幕综合视频 | 国产精品一区二区在线观看免费 | 91av大全| 娇妻呻吟一区二区三区 | 色婷婷狠狠五月综合天色拍 | 在线观看aaa | 四虎8848免费高清在线观看 | 日韩国产欧美视频 | 久久丁香 | 欧洲精品久久久久毛片完整版 | 99久久精品国产毛片 | 国产码电影 | 午夜精品久久久久久久久久 | 国产区久久 | 国产对白av | 国产成人不卡 | 国产午夜影院 | 看av免费网站| 久久99精品久久只有精品 | 国产四虎影院 | 五月综合在线观看 | 久久久久久久久久久高潮一区二区 | 亚洲精品在线观看中文字幕 | 97视频网址| 久久久久久久久久久免费 | 精品一区二区av | 成人av一区二区三区 | 人人爽人人爽人人爽 | 国产视频日韩 | 亚洲午夜精品久久久久久久久久久久 | 国产在线看一区 | 亚洲午夜久久久综合37日本 | 婷婷久久综合九色综合 | 色偷偷网站视频 | 麻豆影视在线播放 | 亚洲国产网站 | japanese黑人亚洲人4k | 久久精品牌麻豆国产大山 | 91色吧| 久久天天躁狠狠躁亚洲综合公司 | 午夜av在线播放 | 天天操天天色天天射 | av成人在线看 | 久久爱综合 | 国产在线不卡精品 | 亚洲免费精彩视频 | 99精品在线免费在线观看 | 在线午夜av| 欧美日韩精品在线视频 | 欧美精品久久天天躁 | 欧美日韩在线精品一区二区 | 欧美色久 | 成人午夜电影网站 | 日本精品久久久一区二区三区 | 亚洲精品一区二区三区高潮 | 午夜精品久久久久久久久久久久 | 99视屏| av色一区| 91日韩免费 | 国产成人综合在线观看 | 玖玖视频| 国产精品久久久久久久免费大片 | 手机av在线网站 | 午夜黄色大片 | 国产在线91在线电影 | www色com | 久久久久久久久久久免费视频 | 日韩精品久久久久久中文字幕8 | 久久精品在线 | 成人cosplay福利网站 | 超碰97国产精品人人cao | 精油按摩av| 亚洲成aⅴ人片久久青草影院 | 午夜精品久久久 | 精品亚洲一区二区三区 | 国产亚洲欧美精品久久久久久 | 亚洲影音先锋 | 8x成人免费视频 | 99精品视频网站 | 国产精品久久久网站 | 亚洲精品乱码久久久久久蜜桃动漫 | 亚洲国产成人在线观看 | 在线观看中文字幕亚洲 | 91中文字幕一区 | 国产精品免费麻豆入口 | 天海冀一区二区三区 | 日韩电影久久久 | 国产精品美女在线观看 | 免费观看www7722午夜电影 | 免费a v网站| 97超碰免费在线观看 | 欧美成年黄网站色视频 | 久久综合中文色婷婷 | 麻豆视频免费看 | 亚洲国产影院av久久久久 | 日本久久综合网 | 国产一区久久 | 日韩精品短视频 | 亚洲毛片久久 | 亚洲精品乱码久久久久v最新版 | 久久精品国产亚洲 | 91网在线看 | av在线进入 | 国产成人av免费在线观看 | 亚洲一区日韩在线 | 亚洲一区二区精品 | 欧美日韩精品免费观看视频 | 国内精品久久久 | 九色91在线 | 国产精品国产三级国产 | 久久精品一二三区 | 激情中文在线 | 中文字幕人成一区 | 国产亚洲成人网 | 国产精品久久久久久久99 | 国产精品久久久久久久久岛 | 精品在线看| 丁香婷婷综合激情五月色 | 超碰在线日韩 | 狠狠色噜噜狠狠狠合久 | 色婷婷狠狠操 | 丁香电影小说免费视频观看 | 亚洲高清在线观看视频 | 精品视频999 | 欧美成年人在线观看 | 高清有码中文字幕 | 国产视频一区在线播放 | 91.麻豆视频| 一级黄色免费网站 | 国产精品成人国产乱一区 | 久综合网 | 欧美一区中文字幕 | 超薄丝袜一二三区 | 午夜精品剧场 | 国产精品永久免费 | 999成人| av网站免费在线 | 亚洲精品国产精品国产 | 狠狠五月婷婷 | 免费精品视频在线 | 久热色超碰 | 日本久久片 | 丁香国产视频 | 久久激情片 | 人人爽人人爱 | 久久免费久久 | 国产一级视屏 | 香蕉视频日本 | 日韩精品一区二区三区水蜜桃 | 亚洲 欧美 日韩 综合 | 亚洲精品久久久久久中文传媒 | 国产精品短视频 | 国产69精品久久久久9999apgf | 国产精品21区 | 国产精品成人自产拍在线观看 | 午夜视频99 | 色wwwww| 97成人资源 | 天天玩天天干 | 天堂网一区 | 久操视频在线播放 | 欧美日一级片 | 五月精品 | 久久国产精品久久国产精品 | 五月在线 | 国产福利91精品 | 欧美成人免费在线 | 久久久免费视频播放 | 99久久精品国产系列 | 天天玩夜夜操 | 久久国内精品 | 日韩精品视频在线免费观看 | 亚洲国产免费看 | 69国产精品视频免费观看 | 久久艹影院 | 久久成人精品电影 | 在线观看亚洲国产精品 | 最近最新最好看中文视频 | 97国产精品免费 | 国产精品18久久久久久首页狼 | 亚洲视频 视频在线 | 黄色1级毛片 | 中文字幕字幕中文 | 欧美国产高清 | 午夜久久影院 | 在线亚州 | 天天综合网天天 | 一区二区三区免费在线观看视频 | 久久69av| 久草精品视频在线看网站免费 | 久久久免费视频播放 | 草樱av| 亚洲精品福利视频 | 一级黄视频 | 在线看日韩 | 成人福利在线观看 | 亚洲视频免费视频 | 久久中文字幕视频 | www.91成人 | 久久er99热精品一区二区 | 日本在线观看视频一区 | 国产成人61精品免费看片 | 一区二区电影在线观看 | av免费网站观看 | 麻豆国产视频下载 | 久久在草 | 91精品久久久久久久91蜜桃 | 久久高清国产视频 | 色av色av色av | adn—256中文在线观看 | 久久精品视频在线免费观看 | 不卡国产在线 | 国产一区二区三区免费在线 | 精品国产123 | 国产一级大片在线观看 | 久草在线99 | 国产在线97 | 2022中文字幕在线观看 | 久久人人爽av | 色偷偷网站视频 | www.精选视频.com | 911免费视频 | 亚洲国产三级在线观看 | 欧美一二三区播放 | 日韩av一区二区三区在线观看 | 尤物97国产精品久久精品国产 | 国产欧美久久久精品影院 | 免费视频成人 | 99久久久久久久久 | 特级a老妇做爰全过程 | 97视频中文字幕 | 久久夜色精品国产欧美乱极品 | 亚洲一区天堂 | 国产又粗又猛又爽又黄的视频免费 | 特级西西444www大精品视频免费看 | 中文字幕久久久精品 | 婷婷久久综合九色综合 | 成人av电影免费在线播放 | 免费看黄色小说的网站 | 91夫妻视频 | 欧美 日韩 性| 久久福利小视频 | 成人av在线看 | 天天操天天干天天插 | 99久久婷婷国产综合精品 | 97超碰中文| 青青草在久久免费久久免费 | 久久一区二区免费视频 | 日韩精品视频第一页 | av一区二区在线观看中文字幕 | 91在线入口 | 亚洲无吗av | 五月婷婷开心 | 福利网在线 | 激情婷婷六月 | 午夜视频在线观看一区二区三区 | 久久免费精品视频 | 丁香激情综合久久伊人久久 | 久草精品视频在线看网站免费 | 伊人五月天婷婷 | 国产一二区在线观看 | 色综合久久久久综合 | 九草在线视频 | 香蕉免费在线 | 国产精品系列在线观看 | 久久久久久久久久免费视频 | 97超视频在线观看 | 国内精品久久久久 | 亚洲成人资源 | 亚洲黄色免费观看 | 91午夜精品| 中文字幕欧美日韩va免费视频 | 免费三级影片 | 中文字幕视频一区 | 日本在线观看中文字幕无线观看 | 欧美一二三四在线 | 久久艹人人 | 99热超碰在线 | 色瓜| 丝袜护士aⅴ在线白丝护士 天天综合精品 | 久久国产成人午夜av影院潦草 | 日韩在线观看av | 日韩在线视频线视频免费网站 | 人人爽人人爱 | 中文字幕资源网 | 久久首页 | 一区二区三区在线免费播放 | 青春草视频在线播放 | 911国产| 黄色1级大片 | 久久视频在线观看 | 视频 天天草 | 97综合网| 国产精品美女久久久久久久网站 | 成人 亚洲 欧美 | 国产麻豆精品在线观看 | 一区二区三区三区在线 | 欧美日韩伦理一区 | 91超碰免费在线 | 五月婷婷中文网 | 成人免费视频免费观看 | av在线播放亚洲 | 麻豆视频免费入口 | 中文字幕一二三区 | 欧美精品午夜 | 日日夜夜精品免费 | 丁香五月亚洲综合在线 | 色婷av| 亚洲一区精品人人爽人人躁 | 国产精品av在线 | 黄色大片中国 | 国产成人a亚洲精品 | 在线观看网站黄 | 欧美一区二区三区在线播放 | 69久久99精品久久久久婷婷 | 国产一区二区三区免费观看视频 | 国产精品久久中文字幕 | 国产日韩中文在线 | 精品亚洲视频在线 | 99精品在线直播 | 最近中文字幕mv | 免费在线黄色av | 国产理论影院 | 久久av网 | 五月天丁香亚洲 | 国产人免费人成免费视频 | 成人日批视频 | 在线视频 一区二区 | 久久高清免费视频 | 欧美九九九 | 国产成人中文字幕 | 国产vs久久 | 亚州av免费 | 黄色软件在线看 | 亚洲欧美综合精品久久成人 | 99久久久国产精品 | 精品视频资源站 | 在线免费观看国产黄色 | 在线观看不卡的av | 91桃色在线播放 | 97精品国自产拍在线观看 | 国产成人久久77777精品 | av成人免费在线看 | 久久香蕉国产 | 天天舔天天搞 | 午夜久久视频 | 在线观看视频黄 | 色94色欧美 | 香蕉成人在线视频 | 久久99亚洲网美利坚合众国 | 天堂在线一区二区三区 | 久久线视频 | 国产精品福利视频 | 久久无码av一区二区三区电影网 | 国产护士av | 精品一区在线看 | 亚洲欧洲国产日韩精品 | 天堂av在线网址 | 黄色一级大片在线免费看国产一 | 91经典在线 | 亚洲国产午夜精品 | 日b视频国产 | 一区二区三区污 | 久久高清国产视频 | 国产精品久久久久久久av大片 | 久久图 | 日本婷婷色 | 日韩资源在线观看 | 91桃色在线播放 | 欧美精品久久久久久 | 久久久免费看片 | 久久情侣偷拍 | 国产精品久久艹 | 在线观看成人一级片 | 欧美日韩中文字幕在线视频 | 开心色激情网 |