关于c#:Filter Serilog日志取决于上下文源到不同的接收器?

我有一个.NET Core 2.0应用程序,可以在其中成功使用Serilog进行日志记录。现在,我想将一些数据库性能统计信息记录到一个单独的接收器中(它们不是用于调试的,这基本上是应用程序中所有其他记录的目的,因此我想将它们分开),并认为可以完成此操作 通过使用Log.ForContext()创建数据库统计记录器。

我不知道如何使用我的appsettings.json配置Serilog以将"调试日志"记录到一个接收器,而将数据库统计信息记录到另一个接收器?我希望可以做类似的事情:


"Serilog": {
 "WriteTo": [
    {
     "Name":"RollingFile",
     "pathFormat":"logs/Log-{Date}.log",
     "Filter": {
       "ByExcluding":"FromSource(MyClass)"
      }
    },
    {
     "Name":"RollingFile",
     "pathFormat":"logs/DBStat-{Date}.log",
     "Filter": {
         "ByIncludingOnly":"FromSource(MyClass)"
      }
    }
  ]
}

对我而言,配置的"Filter"部分纯属猜测。是否可以使用我的配置文件管理器执行此操作,还是需要在我的Startup.cs文件中的代码中执行此操作?

编辑:我已经使用C#API使它工作,但仍然想使用JSON配置来弄清楚它:


Log.Logger = new LoggerConfiguration()
            .WriteTo.Logger(lc => lc
                .Filter.ByExcluding(Matching.FromSource<MyClass>())
                .WriteTo.LiterateConsole())
            .WriteTo.Logger(lc => lc
                .Filter.ByExcluding(Matching.FromSource<MyClass>())
                .WriteTo.RollingFile("logs/DebugLog-{Date}.log"))
            .WriteTo.Logger(lc => lc
                .Filter.ByIncludingOnly(Matching.FromSource<MyClass>())
                .WriteTo.RollingFile("logs/DBStats-{Date}.log", outputTemplate:"{Message}{NewLine}"))
            .CreateLogger();

 相关讨论

我今天完成了这项工作,并认为我会提供一个正确的答案,因为我花了很多篇文章,问题和其他页面来解决问题。

拥有所有日志非常有用,但是我还想单独记录我的API代码,并省略Microsoft.命名空间日志。进行此操作的JSON配置如下所示:


 "Serilog": {
   "Using": ["Serilog.Sinks.File" ],
   "MinimumLevel":"Debug",
   "WriteTo": [
      {
       "Name":"File",
       "Args": {
         "path":"/var/logs/system.log",
          ... //other unrelated file config
        }
      },
      {
       "Name":"Logger",
       "Args": {
         "configureLogger": {
           "WriteTo": [
              {
               "Name":"File",
               "Args": {
                 "path":"/var/logs/api.log",
                  ... //other unrelated file config
                }
              }
            ],
           "Filter": [
              {
               "Name":"ByExcluding",
               "Args": {
                 "expression":"StartsWith(SourceContext, 'Microsoft.')"
                }
              }
            ]
          }
        }
      }
    ],
   "Enrich": ["FromLogContext","WithMachineName","WithThreadId" ]
    ... //Destructure and other config
  }

顶级WriteTo是第一个简单的全局接收器。所有日志事件都将写入此内容。如果在与此相同的级别上添加Filter部分,它将影响所有已配置的WriteTo元素。

然后,我将另一个WriteTo配置为Logger(不是File),但是Args看上去与此不同,并且具有一个configureLogger元素,其作用与顶层的Serilog相同,即也就是说,它是子记录器的顶层。这意味着您可以轻松地将此配置拆分为一个单独的文件,并将其另外添加到配置构建器中(请参阅底部)。

从这里开始,此子记录器的工作方式相同:您可以配置多个WriteTo,并且此级别上的Filter元素将仅影响此子记录器。

只需将更多"Name":"Logger"元素添加到顶层WriteTo部分,并分别为每个元素设置过滤器。

注意
同样重要的是要注意,即使您在config中完成所有这些操作,并且没有在代码中引用Serilog.Filters.Expressions包的任何一点,您仍然必须向该包添加NuGet引用。没有软件包参考,它将无法正常工作。

关于拆分配置:

如果必须添加更多的记录器,为了清楚起见,我一定会将不同的记录器分成单独的文件,例如

appsettings.json:


 "Serilog": {
   "Using": ["Serilog.Sinks.File" ],
   "MinimumLevel":"Error",
   "WriteTo": [
      {
       "Name":"File",
       "Args": {
         "path":"/var/logs/system.log",
          ...
        }
      },
      {
       "Name":"Logger",
       "Args": {
         "configureLogger": {} // leave this empty
        }
      }
    ],
   "Enrich": ["FromLogContext","WithMachineName","WithThreadId" ],
    ...

apilogger.json:


{
 "Serilog:WriteTo:1:Args:configureLogger": {   //notice this key
   "WriteTo": [
      {
       "Name":"File",
       "Args": {
         "path":"/var/logs/api_separateFile.log",
          ...
        }
      }
    ],
   "Filter": [
      {
       "Name":"ByExcluding",
       "Args": {
         "expression":"StartsWith(SourceContext, 'Microsoft.')"
        }
      }
    ]
  }
}

然后调整我的IWebHost构建器以包括其他配置:


    WebHost.CreateDefaultBuilder(args)
        .ConfigureAppConfiguration((hostingContext, config) =>
        {
            config.AddJsonFile("apilogger.json", optional: false, reloadOnChange: false);
        })
        .UseStartup<Startup>();

这样,更易于理解,阅读和维护。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/300933.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C语言数据结构----递归的应用(斐波拉契数列、汉诺塔、strlen的递归算法)

本节主要说了递归的设计和算法实现&#xff0c;以及递归的基本例程斐波拉契数列、strlen的递归解法、汉诺塔和全排列递归算法。 一、递归的设计和实现 1.递归从实质上是一种数学的解决问题的思维&#xff0c;是一种分而治之的思想。 这个是常见的一种数学算法&#xff0c;其实它…

【物理动图】物理老师一针见血:50张动图看懂高中物理

全世界只有3.14 % 的人关注了青少年数学之旅相互作用作用力与反作用力的特点是什么&#xff1f;摩擦力的大小跟什么有关系&#xff1f;图中两个弹簧的弹力大小是否一样&#xff1f;若一样&#xff0c;为什么&#xff1f;自行车前后轮所受力的方向是什么&#xff1f;物块所受支持…

变动翻屏展示图片效果

<HTML><HEAD><TITLE>变动展示图片效果</TITLE><META http-equivContent-Type content"text/html; charsetgb2312" /><STYLE typetext/css>A:link { COLOR: #00007f; TEXT-DECORATION: none}A:visited { COLOR: #00007f; T…

linux expr格式,计算2-expr命令举例

# **一、expr命令**## **1.语法和功能**只能用于整数运算和字符串长度、匹配等运算处理expr 2 2expr 2 - 2expr 2 \* 2expr 2 / 2i5;iexpr $1 6;echo $i> 说明&#xff1a;运算符及用于计算的数字左右都至少有一个空格&#xff0c;否则会报错乘号需要转义在shell中进行变量…

打造史上最小尺寸.Net Core单文件应用程序

.Net Core支持将应用程序发布成单文件进行部署和分发。以下示例将Windows应用作为独立的单文件应用程序发布&#xff1a;dotnet publish -r win-x64 -c Release /p:PublishSingleFiletrue /p:PublishTrimmedtrue /p:IncludeNativeLibrariesForSelfExtracttrue查看publish目录&a…

别说了,叫爸爸吧! | 今日最佳

全世界只有3.14 % 的人关注了青少年数学之旅&#xff08;视频源网络&#xff0c;侵权删&#xff09;女主最后的微笑意味深长啊↓ ↓ ↓

嵌入式-C语言面试题【转】

1. 用预处理指令#define 声明一个常数&#xff0c;用以表明1年中有多少秒&#xff08;忽略闰年问题&#xff09; #define SECONDS_PER_YEAR (60 * 60 * 24 * 365)UL 我在这想看到几件事情&#xff1a; 1). #define 语法的基本知识&#xff08;例如&#xff1a;不能以分号结束&a…

华硕路由器 linux上不了网,华硕ASUS路由器连不上网怎么办?

在本文中将给大家详细的介绍&#xff0c;华硕(ASUS)路由器连不上网/无法上网的解决办法&#xff0c;请按照下面的步骤进行操作。1. 首先&#xff0c;检查你的宽带是否可以正常使用&#xff0c;可以通过下面的方法进行测试。(1)观察光猫上的指示灯&#xff0c;如果光信号或者LOS…

NHibernate学习笔记(二):one-to-one关系映射

上一篇&#xff1a;NHibernate学习笔记&#xff08;一&#xff09;&#xff1a;初识NHibernate本文的内容&#xff1a;&#xff11;&#xff0e;介绍NH如何处理对象间one-to-ont的映射关系&#xff1b;经验教训&#xff1a;&#xff11;&#xff0e;操作一对一关联关系中的一个…

【汇总】多种方法教你绕过 TPM 2.0 安装 Windows 11 操作系统

此前我们曾介绍三种方法绕过 TPM 2.0 来安装 Windows 11 操作系统。方法一&#xff1a;删除 appraiserres.dll 文件方法二&#xff1a;替换 appraiserres.dll 文件方法三&#xff1a;替换 install.wim 文件今儿我们再谈谈“大法好”的注册表&#xff0c;希望能帮助大家成功安装…

【物理笑话】学过物理的人才能看懂的笑话,你能看明白几个?

全世界只有3.14 % 的人关注了青少年数学之旅1丈夫买了几斤廉价藕&#xff0c;满以为可对妻子炫耀了。不料妻子破口大骂&#xff1a;笨蛋&#xff01;为何不买别的菜&#xff0c;这藕一斤少说也有半斤窟窿啊&#xff01;还说便宜&#xff1f;2第一次坐飞机的两位老妇人在飞机起飞…

c语言分配多一个字符空间,关于C语言动态给字符串分配内存空间问题

在动态分配的空间中如何输入字符串&#xff0c;关于C语言动态给字符串分配内存空间的问题相信很多朋友都不太了解&#xff0c;下面维维带来相关解答&#xff0c;赶紧看看吧。用malloc来分配内存空间。即输入几个字节的字符 系统就自动帮我分配几个字节的大小。。char Str(XXXX)…

在web网页中正确使用图片格式

今天又看了一遍淘宝平四分享的PPT&#xff0c;以前转载网址&#xff1a;http://blog.sina.com.cn/s/blog_995c1f6301017fd2.html

NET问答: 如何在 dynamic 集合上使用 Linq ?

咨询区 user1618825&#xff1a;有没有一种方式可以将 dynamic 对象转成 可过滤的 IEnumerable 类型对象&#xff1f;比如下面的代码&#xff1a;dynamic data JsonConvert.DeserializeObject(response.Content);然后用Linq去访问var a data.Where(p > p.verified true)回…

为什么国外程序员加班少?他们这样评价国内996和技术公众号

有人统计过&#xff0c;我们平均每天花在看内容上的时间是5-6小时与其每天被各种看过就忘的内容占据时间不如看点真正对你有价值的信息下面小编为你推荐几个高价值的公众号它们提供的信息能真正提高你生活的质量长按二维码&#xff0c;选择【识别图中二维码】关注Python爱好者社…

c语言编程每日一练教程,每日一练 | C语言之指针

原标题&#xff1a;每日一练 | C语言之指针练习导言学习 C 语言的指针既简单又有趣。通过指针&#xff0c;可以简化一些 C 编程任务的执行&#xff0c;还有一些任务&#xff0c;如动态内存分配&#xff0c;没有指针是无法执行的。所以&#xff0c;想要成为一名优秀的 C 程序员&…

dynamic flash xml news----滚动新闻

今天有人问起这个问题&#xff0c;抽出晚上的一点时间&#xff0c;做了一个&#xff0c;时间紧难免有不足之处&#xff0c;如果发现bug&#xff0c;请以在贴出。演示&#xff1a;代码&#xff1a;代码://copyright by webstudio.com.cn 2005-4-7 system.useCodepagetrue; Stage…

C# 代码生成二维码方法及代码示例(QRCoder)

背景二维码是越来越流行了&#xff0c;很多地方都有可能是使用到。如果是静态的二维码还是比较好处理的&#xff0c;通过在线工具就可以直接生成一张二维码图片&#xff0c;比如&#xff1a;草料二维码。但有的时候是需要动态生成的&#xff08;根据动态数据生成&#xff09;&a…

你对手机打字一无所知!| 今日最佳

全世界只有3.14 % 的人关注了青少年数学之旅&#xff08;视频源网络&#xff0c;侵权删&#xff09;你真的会打字吗↓ ↓ ↓

because it is not a variable 编译错误解决方案

1&#xff0c;将Stuct换为class 2&#xff0c;使用中间变量&#xff0c; 如Point pnew Point(x,y); this.Locationp; 而不能直接给struct赋值&#xff0c;因为值类型是不能改变的&#xff0c;必须生成新的值类型