如何使用C#在运行时更改Log4net中的日志文件名

时间:2012-05-24 08:08:51

标签: c# web-config log4net

我使用Log4Net在日志文件中写入日志并将其存储在本地临时文件夹位置(C:\ temp ..)。现在我想在运行时更改文本(日志)文件名,所以我在配置文件和我的应用程序中也做了一些代码更改。但无法在本地临时文件夹中更改文件名,并且日志也未写入文本文件。

你能告诉我这个问题的解决方案还是告诉我其他一些例子来解决这个问题?

我的代码是:

我的配置文件(Web.Config)设置:

<appender name="RollingPatternFileAppender"  type="log4net.Appender.RollingFileAppender">
    <file type="log4net.Util.PatternString" value="%property{LogFileName}.log" />
    <appendToFile value="true" />
    <rollingStyle value="Size" />
    <maxSizeRollBackups value="10" />
    <maximumFileSize value="100MB" />
    <staticLogFileName value="false" />
    <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date{yyyy-MM-dd HH:mm:ss} %-5level : [%logger] - %message %newline" />
    </layout>
</appender>
<logger name="SPM.SERVER">
    <level value="DEBUG" />
    <appender-ref ref="RollingPatternFileAppender" />
</logger>

我的应用代码是:

ILog logger = LogManager.GetLogger("SPM.SERVER");
log4net.ThreadContext.Properties["LogFileName"] = "MyLog";
logger.Debug("Load Data",ex);
XmlConfigurator.Configure();

此代码未写入文件内的日志,也未更改文件名。任何人都请在此代码中更正我错误的地方,或者告诉我其他一些示例来实现此解决方案。

1 个答案:

答案 0 :(得分:2)

log4net允许您拥有多个appender。您可以将每个配置为仅侦听特定的一组消息。

看一下这个非常好的documentation集。它有很多关于如何做事的例子。

这是一个相当粗略的例子:

<log4net>
  <appender name="A1" type="log4net.Appender.RollingFileAppender">
    <file value="Errors" />
    <appendToFile value="true" />
    <rollingStyle value="Date" />
    <staticLogFileName value="false" />
    <param name="DatePattern" value="dd.MM.yyyy'.txt'" />
    <layout type="log4net.Layout.PatternLayout">
      <conversionPattern value="%date [%thread] %-5level %logger - %message%newline" />
    </layout>
  </appender>
  <appender name="A2" type="log4net.Appender.RollingFileAppender">
    <evaluator type="log4net.Core.LevelEvaluator">
      <threshold value="DEBUG"/>
    </evaluator>
    <filter type="log4net.Filter.StringMatchFilter">
      <stringToMatch value="Some special message" />
      <acceptOnMatch value="true" />
    </filter>
    <filter type="log4net.Filter.DenyAllFilter" />
    <file value="Debug" />
    <appendToFile value="true" />
    <rollingStyle value="Date" />
    <staticLogFileName value="false" />
    <param name="DatePattern" value="dd.MM.yyyy'.txt'" />
    <layout type="log4net.Layout.PatternLayout">
      <conversionPattern value="%date [%thread] %-5level %logger - %message%newline" />
    </layout>
  </appender>
  <root>
    <appender-ref ref="A1" />
    <appender-ref ref="A2" />
  </root>
</log4net>