2013-02-21 60 views
0

您是否知道是否有一种以编程方式启用某些日志记录级别的方法?NLog启用从命令行进行日志记录

我希望在正常的应用程序使用期间只保留错误日志记录,但能够在需要时通过将命令行参数传递给应用程序来打开更详细的信息。

回答

1

鉴于这样来配置

<targets> 
    <target xsi:type="File" name="payroll" fileName="c:\temp\payroll.log"    
     layout="${longdate} ${uppercase:${level}} ${message}" /> 
</targets> 
<rules> 
    <logger name="*" minlevel="Error" writeTo="payroll" /> 
</rules> 

一个基本的记录仪可以编程方式添加到日志级别

static void Main(string[] args) 
    { 
     if (args.Contains("Info")) 
     { 
      var logger = NLog.LogManager.Configuration.LoggingRules.First(x => x.Targets.First().Name == "payroll"); 
      logger.EnableLoggingForLevel(LogLevel.Info);  
     } 

     var proc = new PayrollProcessor(); 
     proc.Process(); 
    } 
相关问题