繁体   English   中英

格式化 Serilog 日志

[英]Formatting Serilog logs

如何删除 Serilog 日志中不必要的信息? 文档似乎对此一无所知。

我想去掉红色部分

我想去掉上图中的红色部分

这是我在 appsettings.json 中的配置

  "Serilog": {
"Using": [ "Serilog.Settings.Configuration" ],
"Filter": [
  {
    "Name": "ByIncludingOnly",
    "Args": {
      "expression": "@Level in ['Debug']"
    }
  }
],
"MinimumLevel": {
  "Default": "Debug",
  "Override": {
    "System": "Debug",
    "Microsoft": "Debug"
  }
},
"WriteTo": [
  {
    "Name": "Seq",
    "Args": {
      "serverUrl": "http://localhost:5341/",
      "compact": true
    }
  },
  {
    "Name": "Console"
  },
  {
    "Name": "File",
    "Args": {
      "path": "D:\\dev.SmartCity.Peafowls.Logs\\PeafowlsLog_.txt",
      "rollingInterval": "Day",
      "rollOnFileSizeLimit": true,
      "fileSizeLimitBytes": 4194304
    }
  }
] }

它并不完全清楚你想要什么。 我只能假设您只想向控制台显示日志消息。

为此,您可以将以下 outputTemplate 添加到您的块中:

{
    "Name": "Console",
    "Args": {
      "outputTemplate":  "{Message}{NewLine}"
    }
}

问题是我在初始化记录器时在启动 class 中有这条线。 .WriteTo.Providers(providers)这是我现在的配置:

   private void ConfigureLogging(ServiceProvider services, LoggerProviderCollection providers)
    {
        var configuration = services.GetRequiredService<IConfiguration>();

        Log.Logger = new LoggerConfiguration()
            .ReadFrom.Configuration(configuration)
            .Destructure.ByTransforming<ExpandoObject>(e => new Dictionary<string, object>(e))
            .Enrich.WithProperty("Source", "Peafowls")
             #if DEBUG || STAGE
            .Enrich.WithProperty("Environment", _env)
             #endif
            .CreateLogger();
    }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM