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, 方法函数内纯手打就行了。直接干就完事了

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...