.NET核心日志记录中的EventIds与整数:优点是什么?

问题描述

我是新手。我有一个使用Serilog的ASP.NET Core 3应用程序,并接收到Console,Debug和Seq。

记录日志时,我经常使用.LogXXX(EventId eventId,string message,params object[] args)重载并记录特定于应用程序的事件ID的列表,因为我被告知这是一种很好的做法,将来可能会有所帮助。

public static class LogEventIds
{
    public const int JobStarting = 8000;
    public const int JobEnding = 8001;
}
...

Logger.Log@R_513_4045@ion(LogEventIds.JobStarting,"Starting {JobId}",myJobId);

但是在我的LogEventIds中自动创建实体时,重新共享建议我应该将其构造为EventId结构,如

public static class LogEventIds
{
    ...
    public const EventId JobFailed = 8003;
}

与普通的旧整数相比,使用EventId有什么优势?我从文档中只能知道EventId也可以具有name属性。 Serilog是否会输出名称,尤其是Seq?是否需要在输出模板中引用?并且EventId名称认为变量名称吗?因此,在上述情况下,事件ID 8003为“ JobFailed”。这可能使它不仅仅是整数。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)