У меня есть 3 приложения в моем файле конфигурации для создания 3 разных типов журналов. Я использую динамическое именование файла в каждом из трех приложений, задавая свойства глобального контекста. В некоторых случаях мне нужно динамически установить имя файла журнала только для 1 приложения.
Когда я устанавливаю имя файла только для 1 приложения, он создает другой файл с именем "null" без данных в дополнение к фактический файл журнала, имя которого задано динамически. Я создал файл конфигурации, как показано.
<appender name="RollingFileAppenderV1" type="log4net.Appender.RollingFileAppender">
<file type="log4net.Util.PatternString" value="Logs\%property{applog}" />
.
.
.
<appender name="RollingFileAppenderV2" type="log4net.Appender.RollingFileAppender">
<file type="log4net.Util.PatternString" value="Logs\%property{dblog}" />
.
.
.
<logger name="Logger1">
<level value="DEBUG" />
<appender-ref ref="RollingFileAppenderV1" />
</logger>
<logger name="Logger2">
<level value="DEBUG" />
<appender-ref ref="RollingFileAppenderV2" />
</logger>
В коде VB.NET я установил имя файла как:
log4net.GlobalContext.Properties("applog") = "file1.log"
Dim logobj as log4net.Ilog = LogManager.GetLogger("Logger1")
logobj.debug("test")
В этом случае создается «file1.log», а также еще один пустой файл с именем «null». Это происходит только тогда, когда я устанавливаю имя файла любого из приложений во время выполнения. Любая помощь приветствуется.