溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

ASP.NET?Core的日志系統(tǒng)實例分析

發(fā)布時間:2022-07-08 09:40:32 來源:億速云 閱讀:207 作者:iii 欄目:開發(fā)技術(shù)

本文小編為大家詳細介紹“ASP.NET Core的日志系統(tǒng)實例分析”,內(nèi)容詳細,步驟清晰,細節(jié)處理妥當,希望這篇“ASP.NET Core的日志系統(tǒng)實例分析”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學(xué)習(xí)新知識吧。

.net core是內(nèi)置了日志系統(tǒng)的,如下是一個簡單的示例: 

var service = new ServiceCollection()
    .AddLogging(logging => { logging.AddConsole(); });
 
var provider   = service.BuildServiceProvider();
var logFactory = provider.GetService<ILoggerFactory>();
var logger     = logFactory.CreateLogger("MyLogger");
 
logger.LogInformation("hello world. {0}", DateTime.Now);

主要步驟如下:

  • 在DI服務(wù)中通過AddLogging的配置日志服務(wù)

  • 通過DI服務(wù)獲取ILoggerFactory

  • 通過日志工廠創(chuàng)建ILogger

  • 通過ILogger寫日志

需要注意的是,日志是異步輸出的,如果調(diào)用logger.LogInformation后程序馬上結(jié)束,是不會有日志輸出的。

ILogger和ILogger<T>

ILogger是我們實際用-來記錄日志的對象,前面的例子已經(jīng)演示了它的使用方法,在.net core日志系統(tǒng)中,還提供了另一個接口ILogger<T>,它的創(chuàng)建方式如下:

var logger = logFactory.CreateLogger<Program>();

ILogger<T>本身也是繼承自ILogger的,也就是說,他們的用法基本一樣,ILogger<T>的主要區(qū)別是創(chuàng)建的時候無需制定數(shù)據(jù)源名稱,它的數(shù)據(jù)源就是類名,也就是說,它和如下方式創(chuàng)建的ILogger功能基本上是一致的。

var logger = logFactory.CreateLogger(typeof(Program).FullName);

那么為什么要創(chuàng)建一個ILogger<T>呢?我個人認為應(yīng)為因為獲取它是不需要制定參數(shù),更容易和DI框架集成,我們可以通過如下代碼獲取ILogger<T>,而不需要先獲取ILoggerFactory

var logger = provider.GetService<ILogger<Program>>();

日志結(jié)構(gòu)

.net core的日志系統(tǒng)支持不同的日志框架,并且對外統(tǒng)一了日志的格式,不管使用哪種庫,它的格式是一樣的。這樣的好處是切換日志框架時,上層應(yīng)用無需修改。一個基本的日志樣例為:

info: MyLogger[0]
hello world. 03/23/2019 22:37:58

它主要包括如下幾個部分:

  • 日志級別: 日志級別定義在LogLevel枚舉中,它包含如下幾個級別:Trace、Debug、Information、Warning、Error、Critical。另外還有一個特殊級別None,它的值比Critical還高,主要用于關(guān)閉日志輸出, 當配置最小輸出級別時None時,由于它的級別比Critical還高,則所有的日志都不會輸出。

  • 日志源: 用于標志日志的數(shù)據(jù)源,它是一個字符串,保存在具體的ILog對象中,本例中就是"MyLogger"

  • 事件Id: 它標志了日志的序列號,大部分的時候都不會用到它

  • 日志體: 日志內(nèi)容

日志提供程序

ASP.NET Core 內(nèi)置了如下幾種日志提供程序:

  • 控制臺

  • 調(diào)試

  • EventSource

  • EventLog

  • TraceSource

前面的示例中,如果要增加其他的日志提供程序,可以在DI框架初始化的時候進行。 

var service = new ServiceCollection()
    .AddLogging(logging => { logging.AddConsole(); });
 
var provider   = service.BuildServiceProvider();
var logFactory = provider.GetService<ILoggerFactory>();
var logger     = logFactory.CreateLogger("MyLogger");
 
logger.LogInformation("hello world. {0}", DateTime.Now);

雖然系統(tǒng)內(nèi)置了這些日志框架比較方便,但實際上用起來是不夠用的,比如說它不能輸出到文件,不過好在.net core提供了比較強大的擴展機制。

采用同樣的方式,我們也可以使用NLog、Seriallog等更為專業(yè)的日志框架,甚至他們已經(jīng)做好了適配,直接拿來用都可以。

  • elmah.io

  • Gelf

  • JSNLog

  • KissLog.net

  • Loggr

  • NLog

  • Sentry

  • Serilog

  • Stackdriver

Log配置文件

一個典型的日志系統(tǒng)的配置文件如下:

{
    "Logging": { 
        "LogLevel": { // 表示全局 
            "Default": "Warning" // 不指定CategoryName,應(yīng)用于所有Category 
        },
        "Console": { // 指定 ProviderName,僅針對于 ConsoleProvider 
            "Default": "Warning",
            "Microsoft": "Error" // 指定CategoryName為Microsoft的日志級別為Error
        }
    }
}

我們可以通過AddConfiguration函數(shù)指定日志配置文件: 

var configBuilder = new ConfigurationBuilder().AddJsonFile("appsettings.json");
var config        = configBuilder.Build();

var service = new ServiceCollection()
    .AddLogging(logging =>
    {
        logging.AddConfiguration(config.GetSection("Logging"));
        logging.AddConsole();
    });

讀到這里,這篇“ASP.NET Core的日志系統(tǒng)實例分析”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領(lǐng)會,如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI