如果服务 运行 连续多天,如何每天创建新的 log4net

How to create new log4net every day if service running continuously from many days

我在我的 windows 服务中实施了 log4net,它按预期工作,并根据配置设置创建了具有当前日期的新文件。

<configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,Log4net" />
  </configSections>
  <log4net>
    <appender name="file" type="log4net.Appender.RollingFileAppender">
      <file type="log4net.Util.PatternString" value="Logs\log-%utcdate{yyyy-MM-dd}.txt" />
      <staticLogFileName value="false" />
      <appendToFile value="true" />
      <rollingStyle value="Composite" />
      <maxSizeRollBackups value="5" />
      <maximumFileSize value="5MB" />
      <staticLogFileName value="true" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %level %logger - %message%newline" />
      </layout>
      <param name="DatePattern" value="dd.MM.yyyy'.log'" />
    </appender>
    <root>
      <level value="ALL" />
      <appender-ref ref="file" />
    </root>
  </log4net>  

这里的问题是,如果我的服务是最近 2 天的 运行,那么它不会创建具有当前日期的新文件,它会保留 2 天前文件的引用并将日志添加到旧文件中而不是为那天创建新文件。
记录器代码就像

public static class Logger
    {
        public static log4net.ILog Log { get; set; }

        static Logger()
        {
            Log = log4net.LogManager.GetLogger(typeof(System.Reflection.MethodBase));
        }

        public static void Trace(string message)
        {
            Log.Info(message);
        }

        public static void LogException(Exception ex)
        {
            StringBuilder builer = new StringBuilder();
            builer.AppendLine("=============Exception===========");
            builer.AppendLine("Exception: {0}");
            builer.AppendLine("StackTrack: {1}");
            Log.ErrorFormat(builer.ToString(), ex.Message, ex.StackTrace);
        }
    }  

要将信息记录到日志文件中,我正在使用代码

Logger.Trace("Hello");  

我需要什么代码级别更改,即使 service/desktop 应用程序从最近几天连续 运行 每天都创建新的日志文件?

您的配置同时包含 <staticLogFileName value="false" /><staticLogFileName value="true" />,这可以解释为什么它不能正确滚动。

我建议您删除 <staticLogFileName value="true" /> 并按如下方式更改文件和 DatePattern:

<file value="Logs\log-" />
...
<param name="DatePattern" value="yyyy-MM-dd'.log'" />

如果 staticLogFileName 为 false,日期字符串将附加到基本文件名,例如:

Logs\log-2018-01-30.log

不过我会注意到 log4net 将 检查它是否需要在您实际记录消息时滚动日志文件,因此如果您不经常记录,它可能第二天开始时不滚动。