Как я могу изменить местоположение файла программно? - PullRequest
71 голосов
/ 08 октября 2009

Я совершенно новичок в Log4net.
Мне удалось что-то сделать, добавив файл конфигурации и простую регистрацию.
Я жестко закодировал значение, равное "C:\temp\log.txt", но этого недостаточно.

Журналы должны идти в специальные папки

path = Environment.GetFolderPath(Environment.SpecialFolder.CommonApplicationData);

и этот путь меняется в зависимости от того, используете ли вы Windows Server 2008 или Windows XP или Vista и т. Д. *

Как мне просто программно изменить местоположение файла в log4net?

Вот что я сделал:

<configSections>
<section name="log4net"
         type="log4net.Config.Log4NetConfigurationSectionHandler,Log4net"/>
</configSections>
<log4net>         
    <root>
        <level value="DEBUG" />
        <appender-ref ref="LogFileAppender" />
    </root>
    <appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
        <param name="File" value="C:\temp\log.txt" />
        <param name="AppendToFile" value="true" />
        <rollingStyle value="Size" />
        <maxSizeRollBackups value="10" />
        <maximumFileSize value="10MB" />
        <staticLogFileName value="true" />
        <layout type="log4net.Layout.PatternLayout">
            <param name="ConversionPattern" value="%-5p%d{yyyy-MM-dd hh:mm:ss} – %m%n" />
        </layout>
    </appender>
</log4net>

class Program
{
    protected static readonly ILog log = LogManager.GetLogger(typeof(Program));

    static void Main(string[] args)
    {
        log4net.Config.XmlConfigurator.Configure();
        log.Warn("Log something");

        path = Environment.GetFolderPath(Environment.SpecialFolder.CommonApplicationData);


        // How can I change where I log stuff?
    }
}

Просто нужно выяснить, как я могу перейти в журнал, где я хочу.

Есть предложения? Большое спасибо

Ответы [ 11 ]

0 голосов
/ 08 октября 2009

В качестве альтернативы программированию вы можете использовать переменные среды и настраиваемые шаблоны в файле конфигурации. Смотрите этот ответ на аналогичный вопрос .

Посмотрите "PatternString для конфигурации на основе шаблона" в заметки о выпуске Log4Net V1.2.10 .

Также, если вы думаете о записи в каталог, такой как Enviroment.SpecialFolder.CommonApplicationData, вы должны учитывать:

  • Будут ли все экземпляры вашего приложения для всех пользователей иметь доступ на запись в файл журнала? Например. Я не верю, что не администраторы смогут писать в Enviroment.SpecialFolder.CommonApplicationData.

  • Конфликт, если несколько экземпляров вашего приложения (для одного и того же или разных пользователей) пытаются использовать один и тот же файл. Вы можете использовать «модель минимальной блокировки» (см. http://logging.apache.org/log4net/release/config-examples.html, чтобы разрешить нескольким процессам выполнять запись в один и тот же файл журнала, но, вероятно, это повлияет на производительность. Или вы можете назначить каждому процессу отдельный журнал файл, например, путем включения идентификатора процесса в имя файла с помощью настраиваемого шаблона.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...