.net 6 web api项目添加日志(Serilog)管理,将日志输出到控制台、文件、数据库
创始人
2024-06-01 08:33:23

1.在nuget安装下面几个包
Serilog
Serilog.AspNetCore
//用于日志输出到控制台
Serilog.Formatting.Compact
//用于日志输出到mysql数据库
Serilog.Sinks.MySQL
//用于日志输出到文件
Serilog.Sinks.RollingFile
在这里插入图片描述
2.在Program.cs文件配置日志参数,依赖注入

// 配置Serilog
Log.Logger = new LoggerConfiguration().MinimumLevel.Override("Microsoft", LogEventLevel.Warning) // 排除Microsoft的日志.Enrich.FromLogContext() // 注册日志上下文.WriteTo.Console(new CompactJsonFormatter()) // 输出到控制台.WriteTo.MySQL(connectionString: builder.Configuration.GetConnectionString("DbConnectionString"), tableName: "Logs") // 输出到数据库.WriteTo.Logger(configure => configure // 输出到文件.MinimumLevel.Debug().WriteTo.File(  //单个日志文件,总日志,所有日志存到这里面$"logs\\log.txt",rollingInterval: RollingInterval.Day,outputTemplate: "{Timestamp:yyyy-MM-dd HH:mm:ss.fff zzz} [{Level:u3}] {Message:lj}{NewLine}{Exception}").WriteTo.RollingFile( //每天生成一个新的日志,按天来存日志"logs\\{Date}-log.txt", //定输出到滚动日志文件中,每天会创建一个新的日志,按天来存日志retainedFileCountLimit: 7,outputTemplate: "{Timestamp:yyyy-MM-dd HH:mm:ss.fff zzz} [{Level:u3}] {Message:lj}{NewLine}{Exception}")).CreateLogger();builder.Host.UseSerilog(); // Register Serilog with the Host

在这里插入图片描述
别忘了在appsettings.json添加数据库连接字符串

 "ConnectionStrings": {"DbConnectionString": "Data Source=48.114.198.199;Database=efcore;AllowLoadLocalInfile=true;User ID=root;Password=root;allowPublicKeyRetrieval=true;pooling=true;CharSet=utf8;port=3306;sslmode=none;"}

在这里插入图片描述
3. 使用日志,在控制器中使用构造函数初始化日志

     [Route("api/[controller]")][ApiController]public class UsersController : ControllerBase{private readonly ILogger _logger;public UsersController( ILogger logger){_logger = logger;}[HttpGet("user")]public object Get(){// 记录日志_logger.LogInformation($"测试测试");return "";}}

在这里插入图片描述

4.调用api,查看效果
在这里插入图片描述

logs表会自动创建

在这里插入图片描述
logs文件夹下会有两个日志文件,一个是总日志文件,一个是按天创建记录的滚动日志文件
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

相关内容

热门资讯

德邦福鑫C净值上涨2.84% 德邦福鑫灵活配置混合型证券投资基金(简称:德邦福鑫C,代码002106)公布6月25日最新净值,上涨...
广发鑫益混合净值上涨1.95% 广发鑫益灵活配置混合型证券投资基金(简称:广发鑫益混合,代码002133)公布6月25日最新净值,上...
Reformation 提交I... 服饰品牌Reformation正式提交IPO招股申请,启动上市流程。译文内容由第三方软件翻译。声明:...
Gunnison Copper... 甘尼森铜业(多伦多证券交易所代码:GCU、美国场外交易市场代码:GCUMF、法兰克福证券交易所代码:...
Reformation拟于纽交... Reformation公司宣布拟在纽约证券交易所挂牌上市普通股,股票代码为“REF”,目前正筹备提交...