1.在nuget安装下面几个包
Serilog
Serilog.AspNetCore
//用于日志输出到控制台
Serilog.Formatting.Compact
//用于日志输出到mysql数据库
Serilog.Sinks.MySQL
//用于日志输出到文件
Serilog.Sinks.RollingFile
2.在Program.cs文件配置日志参数,依赖注入
// 配置Serilog
Log.Logger =newLoggerConfiguration().MinimumLevel.Override("Microsoft", LogEventLevel.Warning)// 排除Microsoft的日志.Enrich.FromLogContext()// 注册日志上下文.WriteTo.Console(newCompactJsonFormatter())// 输出到控制台.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]publicclassUsersController:ControllerBase{privatereadonlyILogger<UsersController> _logger;publicUsersController(ILogger<UsersController> logger){
_logger = logger;}[HttpGet("user")]publicobjectGet(){// 记录日志
_logger.LogInformation($"测试测试");return"";}}
4.调用api,查看效果
logs表会自动创建
logs文件夹下会有两个日志文件,一个是总日志文件,一个是按天创建记录的滚动日志文件
版权归原作者 今夜來看雪 所有, 如有侵权,请联系我们删除。