Log4Net: приложение Rolling File, определите расширение
-
03-07-2019 - |
Вопрос
Я хочу, чтобы мой лог-файл выглядел примерно так: 2009-02-13.log р>
но проблема в том, что я не могу найти способ добавить расширение .log.
Я много чего пробовал, но ничего не помогает. Это то, что у меня так далеко:
<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
<file value="Logs/Log4Net/.log"/>
<appendToFile value="true"/>
<rollingStyle value="Date"/>
<datePattern value="yyyy-MM-dd" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline"/>
</layout>
</appender>
Решение
Попробуйте добавить расширение .log к шаблону даты следующим образом и удалите его из атрибута файла.
<datePattern value="yyyy-MM-dd.lo\g"/>
...
<staticLogFileName value="false" />
Другие советы
Другие ответы избегают " g " в «Журнал» так как "g" это специальный символ в datePattern. Это не так, но я предпочитаю заключать весь набор символов без даты в одинарные кавычки, например так:
<datePattern value="yyyy-MM-dd'.log'" />
Это дает те же результаты, но мне легче управлять. Таким образом, мне не нужно вспоминать, какие конкретные символы являются специальными для datePattern (список длинный и разнообразный). Если я забуду один символ, тогда я не рискую портить имена файлов; все они хорошо сбежали в массовом порядке.
log4net теперь также предоставляет свойство PreserveLogFileNameExtension
, которое может принудительно установить расширение .log до конца составного имени файла (включая шаблон даты и / или порядковый номер размера):
<file value="LogFiles/.log"/>
<preserveLogFileNameExtension value="true" />
<datePattern value="yyyy-MM-dd" />
добавить " .lo \ g " до конца вашего датапаттерна
Это мой файл журнала xml config. Путь к файлу журнала находится в «файле» Тег
Это создаст файл журнала " 2012-11-22.log " в папке «LogFiles»; в папке маршрутов моего сайта.
ПРИМЕЧАНИЕ. Сначала убедитесь, что папка существует!
<?xml version="1.0"?>
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
</configSections>
<log4net>
<root>
<level value="INFO"/>
<appender-ref ref="RollingFileAppender"/>
</root>
<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
<file value="LogFiles/"/>
<appendToFile value="true"/>
<rollingStyle value="Date"/>
<maxSizeRollBackups value="5"/>
<maximumFileSize value="10MB"/>
<datePattern value="yyyy-MM-dd'.log'" />
<staticLogFileName value="false"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %level %logger - %message%newline%exception"/>
</layout>
</appender>
</log4net>
</configuration>