.net 6 web api项目添加日志(Serilog)管理,将日志输出到控制台、文件、数据库

文章介绍了如何在ASP.NETCore项目中集成Serilog,通过NuGet安装相关包,配置日志输出到控制台、MySQL数据库以及滚动文件,并展示了在控制器中如何使用日志。配置包括设置日志级别、数据库连接字符串以及日志格式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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表会自动创建

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

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值