繁体   English   中英

nlog登录到特定方法

[英]nlog to log to specific methods

我正在使用nlog将日志写入文件。 目前,当我记录某些内容时,它将记录该类中的所有内容。 例如,我只想记录在特定方法中失败的内容

public void myMethod(){
        try
        {
        }
        catch(Exception ex){
            Logger logger = NLog.LogManager.GetCurrentClassLogger();
            logger.Info("testing");
            logger.Log(LogLevel.Info, "Sample informational message");
        }
}

在这种情况下,您可以使用GetLogger而不是GetCurrentClassLogger

Logger logger = NLog.LogManager.GetLogger("myLogger");

在配置中,您可以对记录器名称进行路由/过滤:

<rule name="myLogger" minLevel="trace" writeTo="myFile"  />

我猜想您想捕获正在进行日志记录的类方法的名称(而不仅仅是类名称)。

在NLog中称为呼叫站点(可以在呼叫站点提供类名,成员函数名,源文件和行号):

https://github.com/NLog/NLog/wiki/Callsite-layout-renderer

激活该功能会产生巨大的开销(将为每个日志事件捕获完整的StackTrace),因此启用该功能时要小心(但为每个日志事件调用GetCurrentClassLogger()一样昂贵)。

另外,您可以通过包装NLog-Logger并使用“调用者信息”属性来自己捕获信息(性能更好):

https://docs.microsoft.com/zh-cn/dotnet/csharp/programming-guide/concepts/caller-information

暂无
暂无

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

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