我正在尝试以编程方式在 C# 中创建滚动文件附加程序。我正在使用 Visual Studios 2008。我正在使用 log4net 版本 1.2.0.30714。
我的主要问题是我的滚动文件附加程序就像文件附加程序一样。日志文件不会根据我给它的任何大小或日期标准滚动。以下是我的配置,我将不胜感激任何见解或建议。下面的代码是我尝试过的一些想法。
string path = "Logs\";
string filename = "test.log";
if (!Directory.Exists(path))
{
Directory.CreateDirectory(path);
}
log4net.Layout.PatternLayout patternLayout = new log4net.Layout.PatternLayout("[%d] %l %n - %m %n%n");
patternLayout.ActivateOptions();
RollingFileAppender appender = new RollingFileAppender();
appender.Threshold = Level.ALL;
appender.StaticLogFileName = false;
appender.CountDirection = 0; // Makes the logs count 1, 2, 3
appender.RollingStyle = RollingFileAppender.RollingMode.Size;
appender.MaximumFileSize = "1KB";
appender.MaxFileSize = 1 * 1024; // 1 KB
appender.MaxSizeRollBackups = 5;
appender.DatePattern = "yy.MM.dd.hh.mm.ss";
appender.Layout = patternLayout;
appender.Name = "QTracImportHelper";
appender.ImmediateFlush = true;
appender.File = filename;
appender.Writer = new StreamWriter(path + filename, true);
appender.ActivateOptions();
Hierarchy hierarchy = (Hierarchy)LogManager.GetLoggerRepository();
hierarchy.Root.AddAppender(appender);
hierarchy.Configured = true;
我注意到删除 StreamWriter 会导致根本没有创建文件,但没有例外。删除文件名会导致 log4net 中出现异常。我尝试同时使用 MaxFileSize 和 MaximumFileSize 都无济于事,并将滚动阶梯更改为 Date 和 Composite。此外,如果编写器流格式错误,它将创建与不包含 File 属性相同的异常({"Value cannot be null.\r\nParameter name: fileName"}{System.ArgumentNullException})。