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<UsersController> _logger; public UsersController( ILogger<UsersController> logger) { _logger = logger; } [HttpGet("user")] public object Get() { // 记录日志 _logger.LogInformation($"测试测试"); return ""; } }
4.调用api,查看效果
logs文件夹下会有两个日志文件,一个是总日志文件,一个是按天创建记录的滚动日志文件