- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
Using
在 Serilog JSON 配置(例如在 .Net Core 环境中的 AppSettings.json 文件中)实际上做了什么?
让我们以这个配置为例:
"Serilog": {
"Using": [ "Serilog.Sinks.Console" ], <=======***HERE***=========
"MinimumLevel": "Debug",
"WriteTo": [
{ "Name": "Console" },
{
"Name": "RollingFile",
"Args": {
"pathFormat": "logs\\log-{Date}.txt",
"outputTemplate": "{Timestamp:yyyy-MM-dd HH:mm:ss.fff zzz} [{Level}] {Message}{NewLine}{Exception}"
}
}
],
"Enrich": [ "FromLogContext", "WithMachineName", "WithThreadId" ],
"Properties": {
"Application": "My Application"
}
}
File
sink
而没有 将它添加到
Using
属性。但是,一切似乎都正常。
Using
。有人可以向我解释一下吗?
最佳答案
这在 Serilog.Settings.Configuration
的文档中有介绍:
(This package implements a convention using
DependencyContext
to find any package withSerilog
anywhere in the name and pulls configuration methods from it, so theUsing
example above is redundant.)
Serilog.Settings.Configuration
包时它是多余的。
Using
究竟做了什么以及为什么首先需要它的信息。我希望下面的解释有帮助。
Log.Logger = new LoggerConfiguration()
.WriteTo.Console()
.CreateLogger();
Console
是
LoggerSinkConfiguration
的扩展方法(因此它的第一个参数是
LoggerSinkConfiguration
的一个实例)。使用这种基于代码的方法时,只有在引用的程序集中可以找到此扩展方法时,代码才会编译。
IConfiguration
的方法:
Log.Logger = new LoggerConfiguration()
.ReadFrom.Configuration(someConfiguration)
.CreateLogger();
{
"Serilog": {
"Using": ["Serilog.Sinks.Console"], // Redundant.
"WriteTo": ["Console"]
}
}
"Console"
指的是什么,因此需要一个可以从字符串
"Console"
到上述
Console()
扩展方法的过程。为此,Serilog 需要首先在运行时找到扩展方法(在本例中,它位于
Serilog.Sinks.Console
程序集中)。
public static
methods that take as their first parameter a LoggerSinkConfiguration
进行了一些汇编扫描。在查找这些扩展方法时,您在问题中询问的
Using
指令是
mechanism for helping determine exactly which assemblies should be scanned 。
IConfiguration
的方法使用
DependencyContext
来
automatically scan assemblies that have Serilog
in their name 。由于
Serilog.Sinks.Console
的名称中确实包含
Serilog
,因此无需将其添加到
Using
指令中。使用此方法时,您还可以选择
provide your own DependencyContext
instance,因此您可能需要明确说明在查找接收器时要扫描哪些程序集。
关于c# - Serilog JSON 配置中的 "Using"有什么作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53796152/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!