我的配置文件中有 3 个附加程序,用于创建 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”的空文件。仅当我在运行时设置任一附加程序文件名时才会发生这种情况。任何帮助表示赞赏。