C# 日志框架Serilog使用

1、框架和说明

C#日志框架Serilog支持多种场景输出,简单验证了一下,比较方便

包的安装,推荐直接使用"推荐NuGet包管理器"安装Serilog.AspNetCore,常见的组件都已经集成在一个包中,使用比较方便

2、配置文件

Serilog可以由配置文件来定义行为,而且配置文件的修改即时生效。参考配置文件如下:

cs 复制代码
{
  "Serilog": {
    "Using": [ "Serilog.Sinks.File", "Serilog.Sinks.Console" ], // 引入Serilog.Sinks.Console  
    "MinimumLevel": "Debug", // 默认的最低日志级别,LogEventLevel.Debug/Information/Warning/Error/Fatal
    "WriteTo": [
      {
        "Name": "File", // 使用文件接收器
        "Args": {
          "path": "logs/log-.txt", // Debug日志文件的路径  
          "rollingInterval": "Day", // 每天滚动日志文件  
          "outputTemplate": "[{Timestamp:yyyy-MM-dd HH:mm:ss} {Level:u3}] {Message:lj}{NewLine}", // 可选的输出模板  
          //"outputTemplate": "[{Timestamp:yyyy-MM-dd HH:mm:ss} {Level:u3} {SourceContext}] {Message:lj} {NewLine}", // 不同的输出模板  
          "restrictedToMinimumLevel": "Debug" // 限制此接收器仅接收Debug及以上级别的日志  
        }
      },
      {
        "Name": "Console", // 使用控制台接收器
        "Args": {
          "outputTemplate": "[{Timestamp:yyyy-MM-dd HH:mm:ss} {Level:u3}] {Message:lj} {NewLine}", // 控制台输出模板  
          "restrictedToMinimumLevel": "Debug" // 限制此接收器接收Debug及以上级别的日志  
        }
      }
    ],
    "Enrich": [ "FromLogContext", "WithMachineName", "WithThreadId" ] // 可选的日志丰富器  
  }
}

这个配置文件定义了2个输出,可以同时输出到文件和控制台。

3、使用验证

cs 复制代码
using Microsoft.Extensions.Configuration;
using Serilog;
using Serilog.Events;


// 构建配置  
var configuration = new ConfigurationBuilder()
    .AddJsonFile("serilog.json", optional: false, reloadOnChange: true)
    .Build();

Log.Logger = new LoggerConfiguration()
            .ReadFrom.Configuration(configuration)
            .CreateLogger();

Log.Information("log");
Log.Error("Error");

4、注意事项

4.1日志淘汰

日志可以启用保留多少时间的,过期自动清理。但如果非连续运行,超期的过期日志文件不会自动删除。建议在启动时写个代码检查一下,有过期的手工删除

4.2多日志输出

配置时可以同时配置不同的输出文件,但没有适配器都是独立工作的,由"restrictedToMinimumLevel"参数决定最低的适配级别,没有最高的适配级别。如果配置Debug、Info、Error三个适配器,会同时工作,Debug的会包含Info和Error的输出,Error的仅包含Error和Fatal的输出。

相关推荐
我是唐青枫39 分钟前
C#.NET SpinLock 深入解析:自旋锁原理、使用边界与性能取舍
c#·.net
似水明俊德1 小时前
13-C#.Net-设计模式六大原则-学习笔记
笔记·学习·设计模式·c#·.net
无心水1 小时前
【时间利器】5、多语言时间处理实战:Go/C#/Rust/Ruby统一规范
golang·rust·c#·时间·分布式架构·openclaw·openclaw变现
似水明俊德2 小时前
16-C#.Net-自研ORM框架-学习笔记
windows·笔记·学习·c#·.net
A_nanda3 小时前
C#类型转换最佳实践
java·jvm·c#
唐青枫3 小时前
C#.NET System.Threading.Lock 深入解析:新一代 lock、底层语义与使用边界
c#·.net
步步为营DotNet3 小时前
全面解读C# 14在云原生微服务开发中的创新应用
微服务·云原生·c#
Traced back14 小时前
怎么用 Modbus 让两个设备互相通信**,包含硬件接线、协议原理、读写步骤,以及 C# 实操示例。
开发语言·c#
一个帅气昵称啊14 小时前
基于.NET AgentFramework开发OpenClaw智能体框架
人工智能·自然语言处理·c#·.net·openclaw
唐青枫15 小时前
C#.NET SpinLock 深入解析:自旋锁原理、使用边界与性能取舍
c#·.net