当前位置: 首页 > article >正文

Asp.Net Core 8.0 使用 Serilog 按日志级别写入日志文件的两种方式

1、所需的Nuget包

        本文项目的版本是.NET 8.0,如果使用其它版本安装适配版本即可。

Serilog.AspNetCore(8.0.2)

Serilog.Sinks.File(5.0.0)

Serilog.Expressions(5.0.0)

2、两种配置方式

2.1 代码形式(Program.cs)

    在Program.cs文件中,添加如下代码

//设置Serilog为日志管理
builder.Host.UseSerilog((context, loggerConfiguration) =>
{
    loggerConfiguration.MinimumLevel.Override("Microsoft", LogEventLevel.Warning)//最小日志级别
        .Enrich.FromLogContext()
        
        .WriteTo.Console()//输出到控制台
        
        //按日志级别分别写入不同的日志文件中(可设置参数outputTemplate模板,有默认这里就不设置了)
        .WriteTo.Logger(configure => configure
             .Filter.ByIncludingOnly(e => e.Level == LogEventLevel.Information)//过滤
             .WriteTo.File("Logs/Info/info.txt", rollingInterval: RollingInterval.Day))
        
        .WriteTo.Logger(configure => configure
             .Filter.ByIncludingOnly(e => e.Level == LogEventLevel.Warning)//过滤
             .WriteTo.File("Logs/Warn/warn.txt", rollingInterval: RollingInterval.Day))
        
        .WriteTo.Logger(configure => configure
             .Filter.ByIncludingOnly(e => e.Level == LogEventLevel.Error)//过滤
             .WriteTo.File("Logs/Error/error.txt", rollingInterval: RollingInterval.Day));
});
 

2.2 配置文件形式(appsetting.json)

    2.2.1、appsetting.json文件添加如下配置信息

"Serilog": {
  "Using": [ "Serilog.Sinks.File" ],
  "MinimumLevel": {
    "Default": "Information",//默认日志输出级别
    "Override": {
      "Microsoft": "Warning",
      "System": "Warning"
    }
  },
  "WriteTo": [

    { "Name": "Console" },//输出到控制台

    {//info
      "Name": "Logger",
      "Args": {
        "configureLogger": {
          "Filter": [//过滤
            {
              "Name": "ByIncludingOnly",
              "Args": {
                "expression": "@l = 'Information'"
              }
            }
          ],
          "WriteTo": [//写入
            {
              "Name": "File",
              "Args": {
                "path": "Logs/Info/info.txt",
                "rollingInterval": "Day",
                "outputTemplate": "{Timestamp:yyyy-MM-dd HH:mm:ss.fff} [{Level}] {SourceContext}: {Message}{NewLine}{Exception}{NewLine}"
              }
            }
          ]
        }
      }
    },

    {//warning
      "Name": "Logger",
      "Args": {
        "configureLogger": {
          "Filter": [
            {
              "Name": "ByIncludingOnly",
              "Args": {
                "expression": "@l = 'Warning'"
              }
            }
          ],
          "WriteTo": [
            {
              "Name": "File",
              "Args": {
                "path": "Logs/Warn/warn.txt",
                "rollingInterval": "Day",
                "outputTemplate": "{Timestamp:yyyy-MM-dd HH:mm:ss.fff} [{Level}] {SourceContext}: {Message}{NewLine}{Exception}{NewLine}"
              }
            }
          ]
        }
      }
    },

    {//error
      "Name": "Logger",
      "Args": {
        "configureLogger": {
          "Filter": [
            {
              "Name": "ByIncludingOnly",
              "Args": {
                "expression": "@l = 'Error'"
              }
            }
          ],
          "WriteTo": [
            {
              "Name": "File",
              "Args": {
                "path": "Logs/Error/error.txt",
                "rollingInterval": "Day",
                "outputTemplate": "{Timestamp:yyyy-MM-dd HH:mm:ss.fff} [{Level}] {SourceContext}: {Message}{NewLine}{Exception}{NewLine}"
              }
            }
          ]
        }
      }
    }
  ],
  "Enrich": [ "FromLogContext", "WithThreadId" ]
}
 

2.2.2、在Program.cs文件中添加如下代码进行Serilog的注册使用 

//设置Serilog为日志管理
builder.Host.UseSerilog((context, loggerConfiguration) =>
{
    //读取配置文件中Serilog配置信息
    loggerConfiguration.ReadFrom.Configuration(context.Configuration);
});
 

3、实现效果如下

    Logs/Info/info.txt 指定的日志文件路径是位于项目根路径下

如果您喜欢此文章,请收藏、点赞、评论,谢谢,祝您快乐每一天。  


http://www.kler.cn/a/510785.html

相关文章:

  • 【线性代数】行列式的概念
  • 蓝桥杯训练—斐波那契数列
  • 【记录52】el-table-column 添加fixed属性 滚动条无法滑动
  • Go语言之路————条件控制:if、for、switch
  • SiamCAR(2019CVPR):用于视觉跟踪的Siamese全卷积分类和回归网络
  • Android 项目依赖冲突问题:Duplicate class found in modules
  • USART_串口通讯中断案例(一)(寄存器实现)
  • 缓存商品购物车
  • 【Red Hat8】:搭建DNS和Apache服务器
  • SDL2:arm64下编译使用 -- SDL2多媒体库使用音频实例
  • C++,设计模式,【目录篇】
  • 【C++课程学习】:C++中的IO流(istream,iostream,fstream,sstream)
  • Jenkinsfile共享库介绍
  • Apache Hive--排序函数解析
  • Vue uni-app免手动import
  • Android系统开发(十五):从 60Hz 到 120Hz,多刷新率进化简史
  • Spring Boot 集成 MongoDB:启动即注入的便捷实践
  • JAVA-Exploit编写(6)--http-request库文件上传使用
  • 人机交互(包含推荐软件)
  • STM32 中 GPIO 的八种工作模式介绍
  • 第5章:Python TDD定义Dollar对象相等性
  • pnpm安装
  • AUTOSAR从入门到精通-【自动驾驶】高精地图(五)
  • 接口测试自动化实战(超详细的)
  • 若依框架搭建学习
  • Electron实践继续