.Net Core日志記錄之自定義日志組件
一、前言
在上一篇中,我們通過學(xué)習(xí)了解在.net core 中內(nèi)置的日志記錄中的幾大核心要素,在日志工廠記錄器(ILoggerFactory
)中實現(xiàn)將日志記錄提供器(ILoggerProvider
)對象都可以集成到Logger
對象組合中,這樣的話,我們就可以通過基于ILoggerProvider
自定義日志記錄程序集成到Logger
中,再創(chuàng)建寫日志定義Ilogger
,自定義日志記錄器實現(xiàn)日志的輸出方式,這樣實現(xiàn)自定義日志記錄工具。
在這個過程中,日志記錄器ILogger
中的Log()方法會記錄執(zhí)行日志,通過在ILoggerFactory
產(chǎn)生的是ILogger
類型(也就是我們最終使用的Logger
),其Log()方法是依次調(diào)用Logger
中包含的LoggerInformation[]
數(shù)組中的ILogger
。而ILoggerProvider
產(chǎn)生的為各類不同的XxxLogger(也就是上面說的Logger
中的LoggerInformation
數(shù)組包含的如ConsoleLogger、DebugLogger
),其Log()方法是把日志寫到具體的目標(biāo)上去,所以我們自定義的日志程序也可以在日志記錄器工廠中實現(xiàn)添加日志程序,達(dá)到將日志寫到具體目標(biāo)的作用。
所以下文我們通過自定義的方式實現(xiàn)ILogger
、ILoggerProvider
兩個接口來實現(xiàn)我們自己想要的日志記錄程序,實現(xiàn)自定義輸出目標(biāo)方式。(下文只是簡單的根據(jù)接口自定義實現(xiàn)輸出日志記錄到控制臺的demo)
二、開始
2.1 自定義Logger
創(chuàng)建一個自定義Logger,目的是將指定的等級日志輸出到控制臺。所以我們創(chuàng)建一個ExtensionLogger
的類,指定輸出的日志等級。所以在這之前,我們需要配置一下輸入日志的等級,因此我們需要增加一個等級的配置類ExtensionsConfiguration
。
在ExtensionsConfiguration
中,
public class ExtensionsConfiguration { /// <summary> /// 日志等級 /// </summary> public LogLevel LogLevel { get; set; } = LogLevel.Warning; }
再自定義日志記錄類ExtensionLogger
,實現(xiàn)接口ILogger
,
public class ExtensionsLogger : ILogger { private readonly ExtensionsConfiguration _config; public ExtensionsLogger(ExtensionsConfiguration extensionsConfiguration) { _config = extensionsConfiguration; } public IDisposable BeginScope<TState>(TState state) { return null; } public bool IsEnabled(LogLevel logLevel) { return logLevel == _config.LogLevel; } public void Log<TState>(LogLevel logLevel, EventId eventId, TState state, Exception exception, Func<TState, Exception, string> formatter) { if (!IsEnabled(logLevel)) { return; } Console.WriteLine($" {logLevel} - {eventId.Id} : " + formatter(state, exception)); } }
根據(jù)ILogger
接口實現(xiàn),其中實現(xiàn)Log()
接口方法,將日志輸出到指定目標(biāo),這里是輸出到控制臺,在設(shè)置了日志等級的情況條件下,當(dāng)滿足條件后,才能輸出對應(yīng)的日志。
2.2 自定義LoggerProvider
在創(chuàng)建了日志輸出記錄后,我們同時需要提供一個日志程序來增加和創(chuàng)建上面的Logger
記錄,所以我們通過自定義日志提供器類ExtensionsLoggerProvider
,實現(xiàn)ILoggerProvider
類。
public class ExtensionsLoggerProvider : ILoggerProvider { private readonly ExtensionsConfiguration _config; public ExtensionsLoggerProvider(ExtensionsConfiguration extensionsConfiguration) { _config = extensionsConfiguration; } public ILogger CreateLogger(string categoryName) { return new ExtensionsLogger(_config); } public void Dispose() { } }
基于ILoggerProvider
接口實現(xiàn)自定義類,實現(xiàn)方法CreateLogger
,來創(chuàng)建上面的日志記錄。
2.3 使用
在Startup.cs中,通過Configure
方法調(diào)用配置日志記錄。
public void Configure(IApplicationBuilder app, IWebHostEnvironment env , ILoggerFactory loggerFactory) { if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } // 注入ILogggerFactory,然后配置參數(shù) //添加日志等級 loggerFactory.AddProvider(new ExtensionsLoggerProvider(new ExtensionsConfiguration { LogLevel= LogLevel.Warning })); app.UseRouting(); app.UseAuthorization(); app.UseEndpoints(endpoints => { endpoints.MapControllers(); }); }
在此之前,我們可以清空默認(rèn)的配置,然后根據(jù)日志等級,在控制臺中輸出對應(yīng)的日志記錄。
2.4 效果
在等級為Information
情況下,輸出效果如下:
這個就是我們通過自定義的方式實現(xiàn)的按日志等級輸出的記錄。
三、拓展
3.1 寫入本地文件
第一步:為LoggerFactory擴(kuò)張一個方法,提供增加日志寫文件方式的入口。相關(guān)的配置來自appsettings.json
第二步:實現(xiàn)我們的logger提供程序,實現(xiàn)ILoggerProvider接口,關(guān)鍵方法CreateLogger,創(chuàng)建真正寫日志的logger。對當(dāng)前的logger可以做適當(dāng)?shù)木彺妫渲胠ogger
第三步:實現(xiàn)我們的logger,實現(xiàn)ILogger接口。真正將log寫入file。
這里可以參考網(wǎng)友的資料 :.Net Core Logger 實現(xiàn)log寫入本地文件系統(tǒng)
四、總結(jié)
上文中,我們通過自定義的方式實現(xiàn)了根據(jù)日志等級將日志記錄輸出到指定目標(biāo)的方式,在這種基礎(chǔ)上,我們可以根據(jù)具體的需求做完善修改,實現(xiàn)自己的日志記錄輸出方式。
除了我們通過自定義的方式之外,我們也可以借用第三方日志框架組件程序進(jìn)行使用,根據(jù)拓展方法進(jìn)行調(diào)用,在后續(xù)中我們會使用第三方日志記錄程序來實現(xiàn)日志記錄的輸出。
如果有不對的或不理解的地方,希望大家可以多多指正,提出問題,一起討論,不斷學(xué)習(xí),共同進(jìn)步。
本文項目源碼下載
到此這篇關(guān)于.Net Core自定義日志組件的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
給Asp.Net初學(xué)者的關(guān)于繼承和多態(tài)性的例子
給Asp.Net初學(xué)者的關(guān)于繼承和多態(tài)性的例子...2006-09-09ASP.NET Core使用HttpClient調(diào)用WebService
這篇文章介紹了ASP.NET Core使用HttpClient調(diào)用WebService的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03.Net平臺開發(fā)實踐的一些點滴總結(jié)(技術(shù)規(guī)范與實踐精華)
以下是本人對.Net平臺開發(fā)實踐的一些點滴總結(jié)。這里的技術(shù)規(guī)范主要是開發(fā)過程的代碼規(guī)范、數(shù)據(jù)庫設(shè)計規(guī)范、Com和.Net互操作規(guī)范;實踐精華是對技術(shù)實踐過程中的部分總結(jié)。2010-04-04.Net連接Oracle數(shù)據(jù)庫的實現(xiàn)代碼
本文使用System.Data.OracleClient方式,這是MS提供的以ADO.NET方式訪問Oracel的驅(qū)動;Oracle也有個Oracle Data Provider for .NET(ODP.NET)下篇再討論。2009-02-02Asp.net實時顯示文本框字?jǐn)?shù)實現(xiàn)代碼
實時顯示文本框字?jǐn)?shù)在日常開發(fā)中很常見,也很實用,接下來為大家介紹下如何實現(xiàn)實時顯示,感興趣的朋友可以參考下哈,希望可以幫助到你2013-04-04asp.net core 集成swagger ui的原理解析
本文主要講解了如何對API進(jìn)行分組,這里僅僅是舉了一個按照API功能進(jìn)行分組的例子,其實在實際開發(fā)中,要按照何種方式分組,可以按照需求靈活定義,比如按照API版本進(jìn)行分組2021-10-10