网易首页 > 网易号 > 正文 申请入驻

Serilog文档翻译系列(三) - 基础配置

0
分享至



Serilog 使用简单的 C# API 来配置日志记录。当需要外部配置时,可以(慎用)通过使用 Serilog.Settings.AppSettings 包或 Serilog.Settings.Configuration 包进行混合配置。

创建日志记录器

日志记录器是通过 LoggerConfiguration 对象创建的:

Log.Logger = new LoggerConfiguration().CreateLogger();
Log.Information("No one listens to me!");
// Finally, once just before the application exits...
Log.CloseAndFlush();

上面的示例将创建一个不记录任何事件的日志记录器。要查看日志事件,必须配置一个接收器。

接收器

日志事件接收器通常将日志事件记录到某些外部表示形式中,最常见的是控制台、文件或数据存储。Serilog 的接收器通过 NuGet 分发。在 Wiki 上,有一个精心整理的可用接收器列表。

这个示例将使用控制台接收器包和文件接收器包,控制台接收器包用于格式化日志数据输出到控制台,文件接收器包用于将日志事件写入一组按日期标记的文本文件。

$ dotnet add package Serilog.Sinks.Console
$ dotnet add package Serilog.Sinks.File

接收器通过 WriteTo 配置对象进行配置。

Log.Logger = new LoggerConfiguration()
.WriteTo.Console()
.CreateLogger();
Log.Information("Ah, there you are!");

多个接收器可以同时激活。如果需要添加额外的接收器可以通过链式调用 WriteTo 块来实现:

Log.Logger = new LoggerConfiguration()
.WriteTo.Console()
.WriteTo.File("log-.txt", rollingInterval: RollingInterval.Day)
.CreateLogger();
输出模板

基于文本的接收器使用输出模板来控制格式。可以通过 outputTemplate 参数进行修改:

.WriteTo.File("log.txt",outputTemplate: "{Timestamp:yyyy-MM-dd HH:mm:ss.fff zzz} [{Level:u3}] {Message:lj}{NewLine}{Exception}")

上面的示例中展示的默认模板使用了内置的属性,如Timestamp和Level。来自事件的属性,包括使用增强器附加的属性,也可以出现在输出模板中。

{Message:lj} 格式选项使消息中的数据以 JSON 格式(j)输出,但字符串文字会原样输出。

添加 {Properties:j} 到输出模板中,以包括额外的上下文信息。

在输出模板中添加{Properties:j}可以包含额外的上下文信息。这允许你将与日志事件相关联的所有属性(包括自定义属性)以 JSON 格式输出到日志文件中,从而提供额外的调试和跟踪信息。

最低级别

Serilog 实现了日志事件处理中常见的“最低级别”概念。

Log.Logger = new LoggerConfiguration()
.MinimumLevel.Debug()
.WriteTo.Console()
.CreateLogger();

MinimumLevel 配置对象允许指定一个日志事件级别作为最低级别。在上面的示例中,级别为 Debug 及更高级别的日志事件将被处理并最终写入控制台。



默认级别 - 如果未指定 MinimumLevel,则将处理 Information 级别及更高级别的事件。

覆盖每个接收器

有时,我们希望将详细的日志写入一个介质,而将不太详细的日志写入另一个介质。

Log.Logger = new LoggerConfiguration()
.MinimumLevel.Debug()
.WriteTo.File("log.txt")
.WriteTo.Console(restrictedToMinimumLevel: LogEventLevel.Information)
.CreateLogger();

在这个例子中,调试级别的日志将被写入到滚动文件中,而只有级别及以上的日志会被写入到控制台。而只有信息级别日志和更高级别的日志将写入控制台

所有提供的接收器都支持 restrictedToMinimumLevel 配置参数。

记录器与接收器的最低级别 - 需要了解的是,日志级别只能提高,而不能降低。也就是说,如果记录器的 MinimumLevel被设置为 Information,那么即使接收器的指定级别为 Debug,它仍然只会接收到 Information 级别的事件。这是因为记录器级别配置是控制哪些日志语句会导致事件的创建,而接收器级别配置是对这些事件进行筛选。如果你想要创建具有更详细级别的单一记录器,那么你应该使用单独的 LoggerConfiguration实例。

增强器

增强器是简单的组件,用于添加、删除或修改附加到日志事件的属性。例如,可以使用 增强器为每个事件附加线程 ID。

class ThreadIdEnricher : ILogEventEnricher
public void Enrich(LogEvent logEvent, ILogEventPropertyFactory propertyFactory)
logEvent.AddPropertyIfAbsent(propertyFactory.CreateProperty(
"ThreadId", Thread.CurrentThread.ManagedThreadId));

增强器是通过 Enrich 配置对象来添加的。

Log.Logger = new LoggerConfiguration()
.Enrich.With(new ThreadIdEnricher())
.WriteTo.Console(outputTemplate: "{Timestamp:HH:mm} [{Level}] ({ThreadId}) {Message}{NewLine}{Exception}")
.CreateLogger();

上面的配置展示了如何通过增强器添加的属性在输出格式化中使用。

如果在应用程序运行期间,增强的属性值是恒定的,可以使用快捷方法 WithProperty 来简化配置。

Log.Logger = new LoggerConfiguration()
.Enrich.WithProperty("Version", "1.0.0")
.WriteTo.Console()
.CreateLogger();

增强器以及它们附加的属性通常与使用结构化存储的接收器一起使用时更加有用,因为在这些接收器中可以查看和过滤属性值。

过滤器

事件可以通过过滤器进行选择性记录。过滤器只是日志事件的筛选规则,其中一些常见场景由 Matching 类处理。

Log.Logger = new LoggerConfiguration()
.WriteTo.Console()
.Filter.ByExcluding(Matching.WithProperty("Count", p => p < 10))
.CreateLogger();
子日志记录器

有时,需要对接收器看到的内容进行更细粒度的控制。为此,Serilog 允许完整的日志记录管道作为接收器使用。

Log.Logger = new LoggerConfiguration()
.WriteTo.Console()
.WriteTo.Logger(lc => lc
.Filter.ByIncludingOnly(...)
.WriteTo.File("log.txt"))
.CreateLogger();

对于子日志记录器处理不佳的场景,可以创建多个独立的顶级管道。虽然 Log.Logger 只能分配一个管道,但你的应用程序可以使用任意数量的额外 ILogger 实例。

请注意,如果在 WriteTo.Logger() 回调中指定了解构策略,则这些策略将不会生效,因为子日志记录器处理的是已经创建的LogEvent对象。

声明:个人原创,仅供参考

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
昆明广告牌坠落致3死调查报告:去年已发现锈蚀严重,城管检查“走过场”

昆明广告牌坠落致3死调查报告:去年已发现锈蚀严重,城管检查“走过场”

澎湃新闻
2024-11-25 12:48:27
彻底刷屏!卖方大佬赵晓光:特斯拉打专利,中国车企全部倒掉...

彻底刷屏!卖方大佬赵晓光:特斯拉打专利,中国车企全部倒掉...

金石随笔
2024-11-25 00:45:23
马斯克的政府效率部,发文揭露美国政府乱花钱:为宣传多元性别,给了缅甸4500万美元

马斯克的政府效率部,发文揭露美国政府乱花钱:为宣传多元性别,给了缅甸4500万美元

不掉线电波
2024-11-25 10:30:11
美日正进一步协调未来台湾“可能发生的紧急事件”,外交部回应

美日正进一步协调未来台湾“可能发生的紧急事件”,外交部回应

澎湃新闻
2024-11-25 15:44:26
“马斯克,将是中国面临的最大挑战”

“马斯克,将是中国面临的最大挑战”

观察者网
2024-11-25 10:32:07
以色列发声:他已被暗杀

以色列发声:他已被暗杀

环球时报国际
2024-11-24 23:13:12
悲剧!网友称深圳龙岗方兴工业园,有中介再也看不到明天的太阳了

悲剧!网友称深圳龙岗方兴工业园,有中介再也看不到明天的太阳了

火山诗话
2024-11-25 06:18:08
美今年第三次遣返中国非法移民,目的地沈阳,不愿回国就送卢旺达

美今年第三次遣返中国非法移民,目的地沈阳,不愿回国就送卢旺达

影孖看世界
2024-11-24 21:45:41
最新!俄方宣布:乌军“最强部队”被歼灭!视频曝光:俄先进导弹摧毁乌方目标!泽连斯基发声

最新!俄方宣布:乌军“最强部队”被歼灭!视频曝光:俄先进导弹摧毁乌方目标!泽连斯基发声

每日经济新闻
2024-11-24 11:11:59
大学生白嫖63家酒店,随身带死蟑螂、脏的避孕套……网友炸了!

大学生白嫖63家酒店,随身带死蟑螂、脏的避孕套……网友炸了!

环球网资讯
2024-11-25 15:33:25
新东方女老师私生活混乱,和男学生发生性关系,被发现后吞J道歉

新东方女老师私生活混乱,和男学生发生性关系,被发现后吞J道歉

社会酱
2024-11-25 14:55:22
被普京政府说中了:美日绝密计划曝光,五角大楼已为中国选好战场

被普京政府说中了:美日绝密计划曝光,五角大楼已为中国选好战场

千里持剑
2024-11-25 13:47:25
野猪闯入家中撕咬老人,医院:失血过多,当场死亡

野猪闯入家中撕咬老人,医院:失血过多,当场死亡

正在新闻
2024-11-25 14:39:27
网友:中年失业不到山穷水尽,不要轻易尝试铁人三项和吉祥三保…

网友:中年失业不到山穷水尽,不要轻易尝试铁人三项和吉祥三保…

火山诗话
2024-11-25 09:55:08
王楚钦夺冠不光彩?被质疑靠遮挡才赢,邓亚萍和张本智和都有发声

王楚钦夺冠不光彩?被质疑靠遮挡才赢,邓亚萍和张本智和都有发声

三十年莱斯特城球迷
2024-11-25 15:14:13
受贿超五千万元,山东省人大常委会原委员崔洪刚获刑14年半

受贿超五千万元,山东省人大常委会原委员崔洪刚获刑14年半

新京报
2024-11-25 16:58:07
十几万横店群演集体调薪,短剧剧组在减少,4年“横漂”加500个群找戏拍

十几万横店群演集体调薪,短剧剧组在减少,4年“横漂”加500个群找戏拍

时代财经
2024-11-24 09:55:33
董宇辉不再担任与辉同行执行董事

董宇辉不再担任与辉同行执行董事

界面新闻
2024-11-25 10:53:03
无力吐槽!因120都是男医生,某高校女生宿舍值班同学,坚决不让医护人员上楼抢救

无力吐槽!因120都是男医生,某高校女生宿舍值班同学,坚决不让医护人员上楼抢救

可达鸭面面观
2024-11-25 09:55:11
终于理解"三代之内有案底不能考公"的规定了!这案例真一针见血啊~

终于理解"三代之内有案底不能考公"的规定了!这案例真一针见血啊~

热闹的河马
2024-11-25 13:54:12
2024-11-25 18:40:49
IT规划师
IT规划师
热爱编程,追求最佳实践,喜欢思想的碰撞
52文章数 905关注度
往期回顾 全部

科技要闻

蔚来李斌内部信:2026年盈利不容有失

头条要闻

特朗普团队给出解决俄乌冲突时间

头条要闻

特朗普团队给出解决俄乌冲突时间

体育要闻

国乒的起伏与夺冠,有些东西已经变了

娱乐要闻

爆料郑雨盛和女模特,女方非正常怀孕

财经要闻

刘煜辉最新演讲全文:蛇的策略

汽车要闻

特斯拉限时优惠:Model Y仅23.99万起 还能5年0息

态度原创

旅游
健康
房产
艺术
家居

旅游要闻

雪下了这么厚!来看银装素裹的箭扣长城

花18万治疗阿尔茨海默病,值不值?

房产要闻

合生把上百个亿万富豪搞破防了

艺术要闻

故宫珍藏的墨迹《十七帖》,比拓本更精良,这才是地道的魏晋写法

家居要闻

素韵留白 极简空间的空灵之境

无障碍浏览 进入关怀版