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

本文关键字:Log4net 日志 文件名 何使用 运行时 | 更新日期: 2023-09-27 18:35:15

我正在使用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();

此代码不会将日志写入文件内部,也不会更改文件名。任何人都可以纠正我在此代码中做错了什么,或者告诉我一些其他示例来实现此解决方案。

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

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

看看这组非常好的文档。它有很多关于如何做事的例子。

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

<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>