Serilog通过appsettings.json把log分离到多个文件

Serilog通过appsettings.json把log分离到多个文件

随着项目项目模块的增加,log也会随之增加,这时分析log就会变得困难。

1.添加依赖

dotnet add package Serilog.Expressions
dotnet add package Serilog.AspNerCore
dotnet add package Serilog.Sinks.File

2.模块Log要通过微软ILogger实现

protected readonly ILogger<T> logger;

3.修改appsettings.josn

 "Serilog": {
   "Using": [ "Serilog.Sinks.File", "Serilog.Expressions" ],
   "MinimumLevel": {
     "Default": "Debug",
   },
   "WriteTo": [
     {
       "Name": "Logger",
       "Args": {
         "configureLogger": {
           "Filter": [
             {
               "Name": "ByIncludingOnly",
               "Args": {
                 "expression": "StartsWith(SourceContext, 'mode1.')"
               }
             }
           ],
           "WriteTo": [
             {
               "Name": "File",
               "Args": {
                 "path": "logs/mode1-.log",
                 "outputTemplate": "[{Timestamp:HH:mm:ss.mmm} {Level:u3}] {Message:lj} {NewLine}{Exception}",
                 "rollingInterval": "Day",
                 "retainedFileCountLimit": 100,
                 "fileSizeLimitBytes": 104857600
               }
             }
           ]
         }
       }
     },
     {
       "Name": "Logger",
       "Args": {
         "configureLogger": {
           "Filter": [
             {
               "Name": "ByIncludingOnly",
               "Args": {
                 "expression": "StartsWith(SourceContext, 'mode2.')"
               }
             }
           ],
           "WriteTo": [
             {
               "Name": "File",
               "Args": {
                 "path": "logs/mode2-.log",
                 "outputTemplate": "[{Timestamp:HH:mm:ss.mmm} {Level:u3}] {Message:lj} {NewLine}{Exception}",
                 "rollingInterval": "Day",
                 "retainedFileCountLimit": 100,
                 "fileSizeLimitBytes": 104857600
               }
             }
           ]
         }
       }
     },

     {
       "Name": "Logger",
       "Args": {
         "configureLogger": {
           "Filter": [
             {
               "Name": "ByIncludingOnly",
               "Args": {
                 "expression": "StartsWith(SourceContext, 'mode3.')"
               }
             }
           ],
           "WriteTo": [
             {
               "Name": "File",
               "Args": {
                 "path": "logs/mode3-.log",
                 "outputTemplate": "[{Timestamp:HH:mm:ss.mmm} {Level:u3}] {Message:lj} {NewLine}{Exception}",
                 "rollingInterval": "Day",
                 "retainedFileCountLimit": 100,
                 "fileSizeLimitBytes": 104857600
               }
             }
           ]
         }
       }
     },

     {
       "Name": "Logger",
       "Args": {
         "configureLogger": {
           "Filter": [
             {
               "Name": "ByExcluding",
               "Args": {
                 "expression": "StartsWith(SourceContext, 'mode1.') or StartsWith(SourceContext, 'mode2.') or StartsWith(SourceContext, 'mode3.') "
               }
             }
           ],
           "WriteTo": [
             {
               "Name": "File",
               "Args": {
                 "path": "logs/Service-.log",
                 "outputTemplate": "[{Timestamp:HH:mm:ss.mmm} {Level:u3}] {Message:lj} {NewLine}{Exception}",
                 "rollingInterval": "Day",
                 "retainedFileCountLimit": 100,
                 "fileSizeLimitBytes": 104857600
               }
             }
           ]
         }
       }
     },
   ]
 }


  • 10
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要更新WPF应用程序中的appsettings.json文件,您可以使用Microsoft.Extensions.Configuration.Json包。以下是一个简单的示例,演示如何使用该包更新appsettings.json文件中的值: 1. 在项目中安装Microsoft.Extensions.Configuration.Json包。 2. 创建一个AppSettings类,其中包含您要更新的属性。 ```csharp public class AppSettings { public string Setting1 { get; set; } public string Setting2 { get; set; } // add more properties as needed } ``` 3. 在App.xaml.cs文件中,添加以下代码以读取appsettings.json文件并将其映射到AppSettings类中的实例: ```csharp public partial class App : Application { public static AppSettings Settings { get; private set; } protected override void OnStartup(StartupEventArgs e) { base.OnStartup(e); var builder = new ConfigurationBuilder() .SetBasePath(Directory.GetCurrentDirectory()) .AddJsonFile("appsettings.json"); var configuration = builder.Build(); Settings = configuration.GetSection("AppSettings").Get<AppSettings>(); } } ``` 4. 要更新appsettings.json文件中的值,请使用以下代码: ```csharp App.Settings.Setting1 = "new value"; var builder = new ConfigurationBuilder() .SetBasePath(Directory.GetCurrentDirectory()) .AddJsonFile("appsettings.json"); var configuration = builder.Build(); configuration.GetSection("AppSettings").Bind(App.Settings); using (var stream = new StreamWriter("appsettings.json")) { stream.Write(JsonConvert.SerializeObject(App.Settings, Formatting.Indented)); } ``` 此代码将更新AppSettings类中的Setting1属性,并将其写入appsettings.json文件。请注意,此代码中的JsonConvert类需要Newtonsoft.Json包的支持。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值