nlog以记录特定方法

时间:2017-12-02 12:24:57

标签: c# nlog

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

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

2 个答案:

答案 0 :(得分:1)

在这种情况下,您可以使用GetLogger代替GetCurrentClassLogger

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

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

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

答案 1 :(得分:1)

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

这在NLog中称为callsite(可以在callsite上提供class-name,member-function-name,source-file和linenumber):

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

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

另外,你可以自己捕获信息,包括NLog-Logger和使用来电者信息属性(更好的性能):

https://docs.microsoft.com/en-us/dotnet/csharp/programming-guide/concepts/caller-information