Недавно поступил вопрос:
A есть возможность писать лог каждый день в новый файл? Чтобы частью имени файла была дата?
Сделать такое можно. Нужно только в конфигурации appender-а написать следующее:
<appender name="DebugFileAppender" type="log4net.Appender.RollingFileAppender"> <lockingModel type="log4net.Appender.FileAppender+MinimalLock" /> <file value="debug" /> <appendToFile value="true" /><rollingStyle value="Date" /> <datePattern value="yyyyMMdd" /> <staticLogFileName value="false" /><maxSizeRollBackups value="10" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%-5p [%d] [%C.%M] %m%n" /> </layout> </appender>
Что же мы тут сделали? У класса RollingFileAppender, который пишет лог в файл, есть такое свойство RollingStyle, которое определяет, когда логгер будет начинать новый файл лога. Допустимы следующие значения:
- Size — новый файл создается, как только лог достигает определенного размера (этот размер задается в свойстве
maximumFileSize). - Date — новый файл создается каждый день, и к названию файла, определенному в свойстве
file, добавляется дата в формате, заданном в свойствеdatePattern. - Composite — комбинирует свойства
DateиSize, т.е. учитываются и размер файла, и дата. Кроме того, данное значение является дефолтным для свойстваRollingStyle. - Once — лог создается один раз при запуске программы.
Итак, в нашем примере мы задали RollingStyle = Date (можно было бы и Composite) и указали формат даты. Но, пока staticLogFileName = true, все это будет игнорироваться, так что надо задать false (эта часть мне несколько непонятна, в документации для staticLogFileName написано другое, но на деле получается именно так). И теперь к имени файла с логом добавляется дата.
NB
Если в datePattern мы напишем что-нибудь вроде yyyyMMdd.log, то файлы, которые будут создаваться, будут называться debug20090808.loA.D.. Это происходит из-за того, что g также является возможным форматом даты. Логгер добросовестно применил этот формат и сообщил, что дата относится к нашей эре (кстати, тоже интересный вопрос: в MSDN написано, что формат эры — gg, а g — это general). Чтобы избежать таких ситуаций, символы, которые являются корректными форматами для дат, надо квотить:
<datePattern value="yyyyMMdd.lo\g" />
Кстати, txt это тоже касается.