.NET?6開發(fā)TodoList應(yīng)用引入第三方日志庫
1.需求
在我們項目開發(fā)的過程中,使用.NET 6自帶的日志系統(tǒng)有時是不能滿足實(shí)際需求的,比如有的時候我們需要將日志輸出到第三方平臺上,最典型的應(yīng)用就是在各種云平臺上,為了集中管理日志和查詢?nèi)罩?,通常會選擇對應(yīng)平臺的日志SDK進(jìn)行集成。使用Serilog提供的多種Sink,可以實(shí)現(xiàn)將日志寫入不同云平臺或者是非云平臺的日志存儲中去,這是我們這篇文章講要研究的內(nèi)容。
2.目標(biāo)
我們將為TodoList添加一個方便替換和擴(kuò)展的日志策略,簡單來說就是在與具體第三方打交道的Infrastructure項目中實(shí)際設(shè)置使用的日志服務(wù),并在Api項目中進(jìn)行依賴注入,方便在整個應(yīng)用程序中無具體日志配置感知地使用日志服務(wù)。
3.原理和思路
查閱Serilog的官方文檔和一些示例后確定,
我們要做的事情有這么幾件:
- 引入
Serilog.AspNetCore包(很多文章或者教程里都讓你根據(jù)需要使用的Sink去繼續(xù)引入類似Serilog.Sink.File之類的包,但是實(shí)際上Serilog.AspNetCore包的依賴項里已經(jīng)包含了File這個Sink,所以實(shí)際上沒有必要再去添加一次); - 二是需要為Serilog的Logger對象提供一個L
oggerConfiguration,可以以代碼的方式進(jìn)行配置,也可以通過加載.json文件的方式進(jìn)行配置,看自己的需求和對配置熱更新的有沒有獨(dú)特的要求決定; - 在程序啟動構(gòu)造
WebApplicationBuilder對象的時候聲明UseSerilog(); - 在需要使用日志的地方注入ILogger<T>對象即可,我們一般是在構(gòu)造函數(shù)里進(jìn)行注入,當(dāng)然也可以選擇其他兩種注入方式。
好了,了解了原理,接下來一步就是想一下我們要在哪里做這幾件事。
在第二篇文章中,我提到了Clean Architecture,里面有一條原則可以理解為:如果系統(tǒng)需要與外部(第三方)系統(tǒng)進(jìn)行集成或交互,那么具體的集成工作應(yīng)該放入Infrastructure層進(jìn)行處理,而程序的其他部分只對外部服務(wù)進(jìn)行抽象的使用。好處是今后如果需要替換第三方系統(tǒng),比如原本日志是寫到本地文件里,后來有了上云和日志集中化處理的需求,需要將日志服務(wù)對接到諸如Azure App Service Logging或者AWS CloudWatch,那么我們只需要去修改(擴(kuò)展)Infrastructure中進(jìn)行日志具體配置的邏輯就可以了。雖然日志服務(wù)本身相對比較簡單,還不能很好地體現(xiàn)這個優(yōu)點(diǎn),我們姑且遵循這個原則,將配置工作放到Infrastructure里面去。
4.實(shí)現(xiàn)
4.1日志配置實(shí)現(xiàn)
我們在TodoList.Infrastructure項目中新增一個文件夾,取名Log,在其中新建文件ConfigureLogProvider.cs,實(shí)現(xiàn)一個針對WebApplicationBuilder的擴(kuò)展方法,為了演示在這里配置的擴(kuò)展性,我多用了一個appsettings.json中的字段來控制配置過程,缺失的包需要安裝一下。
using Microsoft.AspNetCore.Builder;
using Microsoft.Extensions.Configuration;
using Serilog;
namespace TodoList.Infrastructure.Log;
public static class ConfigureLogProvider
{
public static void ConfigureLog(this WebApplicationBuilder builder)
{
if (builder.Configuration.GetValue<bool>("UseFileToLog"))
{
// 配置同時輸出到控制臺和文件,并且指定文件名和文件轉(zhuǎn)儲方式(形如log-20211219.txt格式),轉(zhuǎn)儲文件保留的天數(shù)為15天,以及日志格式
// 配置Enrich.FromLogContext()的目的是為了從日志上下文中獲取一些關(guān)鍵信息諸如用戶ID或請求ID,我們的應(yīng)用中暫時不使用這些。
Serilog.Log.Logger = new LoggerConfiguration()
.Enrich.FromLogContext()
.WriteTo.Console()
.WriteTo.File(
"logs/log-.txt",
outputTemplate: "{Timestamp:yyyy-MM-dd HH:mm:ss.fff zzz} [{Level:u3}] {Message:lj}{NewLine}{Exception}",
rollingInterval: RollingInterval.Day,
retainedFileCountLimit: 15)
.CreateLogger();
}
else
{
// 僅配置控制臺日志
Serilog.Log.Logger = new LoggerConfiguration()
.Enrich.FromLogContext()
.WriteTo.Console()
.CreateLogger();
}
// 使用Serilog作為日志框架,注意這里和.NET 5及之前的版本寫法是不太一樣的。
builder.Host.UseSerilog();
}
}
4.2主程序配置
在TodoList.Api項目的Main.cs中,使用該擴(kuò)展方法:
using TodoList.Infrastructure.Log; var builder = WebApplication.CreateBuilder(args); // Add services to the container. // 配置日志 builder.ConfigureLog(); builder.Services.AddControllers(); // ... 省略以下
并向appsettings.Development.json文件中添加用于測試的配置項:
{
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft.AspNetCore": "Warning"
}
},
"UseFileToLog": true
}
4.3注入使用
嗯……我把第二篇文章結(jié)束時刪除的示例WeatherForecastController.cs和WeatherForecast.cs又加回來了。Controller中已經(jīng)注入了ILogger<WeatherForecastController>,我們就在示例的接口里試一下:
[HttpGet(Name = "GetWeatherForecast")]
public IEnumerable<WeatherForecast> Get()
{
// 記錄日志
_logger.LogInformation($"maybe this log is provided by Serilog...");
return Enumerable.Range(1, 5).Select(index => new WeatherForecast
{
Date = DateTime.Now.AddDays(index),
TemperatureC = Random.Shared.Next(-20, 55),
Summary = Summaries[Random.Shared.Next(Summaries.Length)]
})
.ToArray();
}
好了,到此為止我們就可以驗證一下了。
5.驗證
運(yùn)行TodoList.Api項目,和第二篇文章一樣,我們使用Hoppscotch測試示例接口,觀察控制臺和日志文件的輸出內(nèi)容和格式:
控制臺輸出

文件輸出


總結(jié):
在這篇文章中,我向大家展示了如何在.NET 6 Web API項目中添加第三方日志服務(wù)框架,下一篇文章將會引入數(shù)據(jù)存儲服務(wù)。
到此這篇關(guān)于.NET 6開發(fā)TodoList應(yīng)用引入第三方日志庫的文章就介紹到這了,更多相關(guān)使用.NET 6 TodoList引入第三方日志庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- .NET 6開發(fā)TodoList應(yīng)用之實(shí)現(xiàn)查詢分頁
- .NET 6開發(fā)TodoList應(yīng)用之實(shí)現(xiàn)ActionFilter
- .NET 6開發(fā)TodoList應(yīng)用之實(shí)現(xiàn)接口請求驗證
- .NET?6開發(fā)TodoList應(yīng)用之實(shí)現(xiàn)DELETE請求與HTTP請求冪等性
- .NET 6開發(fā)TodoList應(yīng)用之實(shí)現(xiàn)PUT請求
- .NET 6開發(fā)TodoList應(yīng)用之實(shí)現(xiàn)全局異常處理
- .NET 6開發(fā)TodoList應(yīng)用之使用AutoMapper實(shí)現(xiàn)GET請求
- .NET?6開發(fā)TodoList應(yīng)用之實(shí)現(xiàn)Repository模式
- .NET?6開發(fā)TodoList應(yīng)用之使用MediatR實(shí)現(xiàn)POST請求
- .NET 6開發(fā)TodoList應(yīng)用引入數(shù)據(jù)存儲
- .NET 6開發(fā)TodoList應(yīng)用實(shí)現(xiàn)結(jié)構(gòu)搭建
- .NET?6開發(fā)TodoList應(yīng)用實(shí)現(xiàn)系列背景
- 使用.NET?6開發(fā)TodoList應(yīng)用之引入數(shù)據(jù)存儲的思路詳解
- 使用.NET?6開發(fā)TodoList應(yīng)用之領(lǐng)域?qū)嶓w創(chuàng)建原理和思路
- .NET?6開發(fā)TodoList應(yīng)用之請求日志組件HttpLogging介紹
相關(guān)文章
asp.net 臨時數(shù)據(jù)保存實(shí)現(xiàn)代碼
在一個程序運(yùn)行的時候往往我們會回到上一個頁面,或者我們會需要當(dāng)時留在這個頁面的臨時數(shù)據(jù),例如,我們用百度搜索“腳本”之后我們會看到很多那啥我就不再說了?。∪缓笪覀兎祷乇緛眄撁嬖谖谋究騼?nèi)會有“腳本”的字樣,我們一下代碼段就是實(shí)現(xiàn)這個功能2012-04-04
asp.net Page.EnableEventValidation 屬性驗證服務(wù)器控件的回發(fā)和回調(diào)事件出現(xiàn)的錯誤
Page.EnableEventValidation 屬性驗證服務(wù)器控件的回發(fā)和回調(diào)事件出現(xiàn)的錯誤前兩天用jQuery做了一個包含DropDownList聯(lián)動的頁面,數(shù)據(jù)通過Ajax請求得到的。2010-10-10
教你Asp.net下使用mysql數(shù)據(jù)庫的步驟
近日,在項目中遇到了麻煩,客戶非要求使用mysql數(shù)據(jù)庫,對于我從來么有使用過的人來說,很是頭疼,最后還是硬著頭皮弄好了。期間也遇到了各種各樣的問題,現(xiàn)在把他整理在此,希望對那些和我一樣從來沒有使用過的人,能快速入手2012-05-05
Repeater控件動態(tài)變更列(Header,Item和Foot)信息實(shí)現(xiàn)思路
需求開發(fā)一個小報表,顯示最近五個月的summary的數(shù)量統(tǒng)計,報表會隨月份的變化而變化,接下來為大家詳細(xì)介紹下實(shí)現(xiàn)方法,感興趣的各位不要錯過了哈2013-03-03
asp.net 在DNN模塊開發(fā)中遇到的resx怪問題
最近我遇到2個小問題,在此記錄一下。這是我發(fā)的帖子2008-11-11
asp.net中一個linq分頁實(shí)現(xiàn)代碼
asp.net中一個linq分頁實(shí)現(xiàn)代碼,需要的朋友可以參考下。2011-12-12

