ABP:内置logger and 第三方库serilog 之间的关系
创始人
2024-03-09 03:15:11
0

今天在看项目的日志记录功能,比较疑惑为什么项目中有的地方使用 Logger< T > _logger 然后又在资源文件下看见日志的第三方库 Serilog

解答:

ASP.NET Core Build-in Logging
ASP.NET Core 提供了 Logging 的抽象接口, third party 都会依据抽象来做实现. ASP.NET Core 自己也实现了一套简单的 log, 它只能 log to console. 不能 log to file.

只能输出到控制台,但是不能输出到文件

所以绝大部分项目都会搭配一个 third party library, 比如 Serilog.

Serilog 的 config 不是通过 appsetting 设置的,

如果想用 appsetting 来管理可以另外安装一个 DLL

dotnet add package Serilog.Settings.Configuration 

appsetting 里的 log config 是给 ASP.NET Core build-in log 的, Serilog 不会读取它来用.

所以第0步:装Serilog

dotnet add package Serilog.AspNetCore

第1步:新建一个文件覆写内置的log功能

using System;
using System.IO;
using Serilog;
using Serilog.Events;namespace UIH.RT.HRuiJin.Log
{public class SerilogByMySelf :  ILogger // 看吧serilog要接盘内置的log{private readonly Serilog.Core.Logger _logger;private const string logFilePath = "文件路径.txt";protected string logFileFolder = "日志文件夹的名字";protected string date = DateTime.Today.ToString("yyyyMMdd");protected virtual string LogFilePath => Path.Combine(logFolderName, date, logFilePath);public SerilogByMySelf(){_logger = new LoggerConfiguration().MinimumLevel.Verbose().MinimumLevel.Override("Microsoft", LogEventLevel.Information).MinimumLevel.Override("Microsoft.EntityFrameworkCore", LogEventLevel.Warning).WriteTo.Async("写你的文件路径").CreateLogger();}// 接盘之后也可以加自定义操作public void Warning(object obj){_logger.Warning(obj.ToString());}}
}

第2步:go to the  program.cs 去程序的入口配置

解决答案REF:c# - Use Serilog with Microsoft.Extensions.Logging.ILogger - Stack Overflow

    public class Program{public static int Main(string[] args){SeriLog.Logger = new SerilogFucker();internal static IHostBuilder CreateHostBuilder(string[] args) =>Host.CreateDefaultBuilder(args).ConfigureWebHostDefaults(webBuilder => webBuilder.UseStartup()}).UseSerilog(); // 这一行最重要!!!}

关于内置logger的资料 :ASP.NET Core 源码学习之 Logging[1]:Introduction - 雨夜朦胧 - 博客园

现在面临的问题:

1. 对于微服务的调用记录,存储方式如何? 文件 or 数据库

2. 如果是文件,改代码最方便的方法是新建一个 “Api_History” 文件,在调用proxy api时候对每一个方法手动地添加 _logger.info( ) 

3. 或者适配器模式,抽象出一个适配器类 or 桥接类 or super class虚方法?

4.或者ABP的审计更合适?

2022/12/1

得,问了问TeamLeader, 方法函数内纯手打就行了。直接干就完事了

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...