Как настроить приложение RollingFileAppender для прокрутки по дате и размеру с помощью log4net? - PullRequest
23 голосов
/ 28 октября 2008

Я настроил log4net для использования составного RollingFileAppender, чтобы текущий файл всегда имел имя logfile.log , а все последующие файлы назывались logfile-YYYY.MM.dd.seq.log , где seq - порядковый номер, если журнал превышает определенный размер в течение одного дня. К сожалению, у меня был очень небольшой успех в настройке такой настройки.

Edit:

Моя текущая конфигурация вставлена ​​ниже. Он был обновлен на основе нескольких ответов, что делает меня достаточно близко для моих нужд. Это создает файлы в формате: logfile_YYYY.MM.dd.log.seq

<log4net>

    <root>
        <level value="DEBUG" />
        <appender-ref ref="RollingFileAppender" />
    </root>

    <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
        <file value="logs\\logfile"/>
        <staticLogFileName value="false"/>
        <appendToFile value="true"/>
        <rollingStyle value="Composite"/>
        <datePattern value="_yyyy.MM.dd&quot;.log&quot;"/>
        <maxSizeRollBackups value="10"/>
        <maximumFileSize value="75KB"/>
        <layout type="log4net.Layout.PatternLayout">
            <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline"/>
        </layout>
        <filter type="log4net.Filter.LevelRangeFilter">
            <param name="LevelMin" value="DEBUG" />
            <param name="LevelMax" value="FATAL" />
        </filter>
    </appender>

</log4net>

Одна интересная заметка, настройка

<staticLogFileName value="false"/>

в true приводит к тому, что регистратор не записывает файлы.

Ответы [ 4 ]

15 голосов
/ 28 октября 2008

Мы используем следующее (в Log4J):

<appender name="roller" class="org.apache.log4j.DailyRollingFileAppender">
    <param name="File" value="Applog.log"/>
    <param name="DatePattern" value="'.'yyyy-MM-dd"/>
    <layout class="org.apache.log4j.PatternLayout">
        <param name="ConversionPattern" value="[slf5s.start]%d{DATE}[slf5s.DATE]%n%p[slf5s.PRIORITY]%n%x[slf5s.NDC]%n%t[slf5s.THREAD]%n%c[slf5s.CATEGORY]%n%l[slf5s.LOCATION]%n%m[slf5s.MESSAGE]%n%n"/>
    </layout>
</appender>

Это дает нам Applog.log.yyyy-MM-dd файлы

4 голосов
/ 28 октября 2008

Согласно исходному коду log4net RollingFileAppender:

protected string GetNextOutputFileName(string fileName)
{
    if (!m_staticLogFileName) 
    {
        fileName = fileName.Trim();

        if (m_rollDate)
        {
            fileName = fileName + m_now.ToString(m_datePattern, System.Globalization.DateTimeFormatInfo.InvariantInfo);
        }

        if (m_countDirection >= 0) 
        {
            fileName = fileName + '.' + m_curSizeRollBackups;
        }
    }

    return fileName;
}

Так что я предполагаю, что невозможно создать файл журнала с нужным вам именем. Я думаю, что-то вроде logfileYYYY-MM-dd.n.log или похожее.

1 голос
/ 19 июля 2013

Попробуйте установить для этого свойства значение true:

preserveLogFileNameExtension value = "true"

Я верю, что этот трюк поможет вам! Однако для свойства preserveLogFileNameExtension требуется последняя версия log4net, ее можно найти здесь: logging.apache.org / log4net / download.html

0 голосов
/ 28 октября 2008

Обратите внимание, что в этом случае

            <maxSizeRollBackups value="10"/>

будет игнорироваться.

См. ответ на аналогичный вопрос log4net

...