我可以向特定的appender发送一条日志消息吗?

时间:2018-03-15 14:52:07

标签: c# log4net

我有一个使用文件追加器和控制台追加器的记录器。我的代码中有一行我只想去控制台上传。有没有办法在不制作新记录器的情况下做到这一点?

或者,我可以制作另一个仅使用控制台的记录器,但我似乎无法完成。我可以找到的所有示例都使用类或方法名称。我正在尝试使用我在app.config中提供的名称。

这是我的appconfig:

  <log4net>
    <appender name="Console" type="log4net.Appender.ConsoleAppender">
      <layout type="log4net.Layout.PatternLayout">
        <!-- Pattern to output the caller's file name and line number -->
        <conversionPattern value="%level [%thread] %date - %message%newline" />
      </layout>
      <filter type="log4net.Filter.LevelRangeFilter">
        <param name="LevelMin" value="All" />
      </filter>
    </appender>
    <appender name="RollingFile" type="log4net.Appender.RollingFileAppender">
      <file value="D:\Something\Log\IntegrationTests\IntegrationTests.log" />
      <appendToFile value="false" />
      <rollingStyle value="Size" />
      <maximumFileSize value="250MB" />
      <maxSizeRollBackups value="20" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%level [%thread] %date - %message%newline" />
      </layout>
      <filter type="log4net.Filter.LevelRangeFilter">
        <param name="LevelMin" value="All" />
      </filter>
    </appender>
    <root>
      <level value="ALL" />
      <appender-ref ref="Console" />
      <appender-ref ref="RollingFile" />
    </root>
    <logger name="consoleOnly">
      <level value="ALL" />
      <appender-ref ref="Console" />
    </logger>
  </log4net>

这是我试图获得“consoleOnly”Logger的一行。

ILog log = LogManager.GetLogger("consoleOnly");
log.Debug("Poop");

我是怎么做到的?

1 个答案:

答案 0 :(得分:0)

  

ILog log = LogManager.GetLogger(&#34; consoleOnly&#34;);

     

log.Debug(&#34;船尾&#34);

这应该可以正常工作。但我认为您需要将可加性设置为false,否则它也会使用根记录器进行记录。

例如

def minremo(lst):
    lst.sort()
    lst.reverse()
    lst.pop()
    return lst