Logging 使用log4net直接记录到不同的输出文件

Logging 使用log4net直接记录到不同的输出文件,logging,castle-windsor,log4net,Logging,Castle Windsor,Log4net,我需要将应用程序中的某些事件记录到某个文件中。我有一个正在工作的主日志文件,但如何将特定事件定向到某个文件 在下面的示例中,如何将count属性记录到某个文件中 ILogger mainApplog = container.Resolve<ILogger>(); // this is working just fine to c:\log.txt ILogger valuesLog = container.Resolve<ILogger>(); // what shoul

我需要将应用程序中的某些事件记录到某个文件中。我有一个正在工作的主日志文件,但如何将特定事件定向到某个文件

在下面的示例中,如何将count属性记录到某个文件中

ILogger mainApplog = container.Resolve<ILogger>(); // this is working just fine to c:\log.txt
ILogger valuesLog = container.Resolve<ILogger>(); // what should I resolve to log to c:\values.txt?

mainApplog.DebugFormat("Calculating values");

var count = 0;
while (true)
{

    count++;
    valuesLog.InfoFormat(count.ToString());


    if (count > 100)
        break;
}
mainApplog.DebugFormat("Calculations completed");
ILogger mainApplog=container.Resolve();//这在c:\log.txt中运行正常
ILogger valuesLog=container.Resolve();//我应该解析什么来登录到c:\values.txt?
mainApplog.DebugFormat(“计算值”);
var计数=0;
while(true)
{
计数++;
valuesLog.InfoFormat(count.ToString());
如果(计数>100)
打破
}
mainApplog.DebugFormat(“计算完成”);

如果只是关于Log4Net,请尝试以下操作:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />
  </configSections>
  <startup>
    <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
  </startup>

  <log4net>
    <appender name="MainAppender" type="log4net.Appender.ColoredConsoleAppender" >
      <mapping>
        <level value="ALL" />
        <foreColor value="White" />
        <backColor value="Red, HighIntensity" />
      </mapping>
      <filter type="log4net.Filter.LoggerMatchFilter">
        <LoggerToMatch value="MainApplicationLog" />
      </filter>
      <filter type="log4net.Filter.DenyAllFilter">
      </filter>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger [%ndc] - %message%newline" />
      </layout>
    </appender>

    <appender name="ValueAppender" type="log4net.Appender.ColoredConsoleAppender" >
      <mapping>
        <level value="ALL" />
        <foreColor value="White" />
        <backColor value="Green, HighIntensity" />
      </mapping>
      <filter type="log4net.Filter.LoggerMatchFilter">
        <LoggerToMatch value="ValuesLog" />
      </filter>
      <filter type="log4net.Filter.DenyAllFilter">
      </filter>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger [%ndc] - %message%newline" />
      </layout>
    </appender>

    <root>
      <level value="ALL" />
      <appender-ref ref="MainAppender" />
      <appender-ref ref="ValueAppender" />
    </root>
  </log4net>
</configuration>

通常,您不应该直接解析组件,顶层组件除外。对于日志组件,通常使用日志记录工具()。如果你选择使用它,每个组件都会有自己的日志,你可以配置log4net将不同组件的输出发送到不同的文件。我同意,但我“觉得”没有必要构建自己的日志框架,因为我已经使用log4net来完成几乎相同的任务。但你知道我如何根据目的(与组件相反)指导某些输出吗?你所指的ILogger,是windosr的ILogger还是Log4Net的ILogger?Log4Net(实际上是通过Castle Windsor)但Windsor并不重要,我想知道如何使用Log4Net。
log4net.Config.XmlConfigurator.Configure();

ILog mainAppLog = LogManager.GetLogger("MainApplicationLog");
ILog valuesLog = LogManager.GetLogger("ValuesLog");

mainAppLog.Debug("Calculating values");
valuesLog.InfoFormat("{0}", 0); // do not use ToString, you will use processor time even when not logging