我正在尝试为每个应用程序会话创建一个唯一的日志文件。例如:
使用下面的配置,它会创建文件。但是,我注意到有时它会在同一个会话中创建另一个新文件。应用程序会话期间应该有一个文件。
我使用PatternConverter更新日志文件夹路径,因此可以由用户设置日志路径。
<configuration>
<configSections>
<section
name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
</configSections>
<log4net>
<appender name="MainApplication" type="log4net.Appender.RollingFileAppender">
<file type="log4net.Util.PatternString">
<converter>
<name value="folder" />
<type value="MyApp.MainAppLogPatternConverter" />
</converter>
<conversionPattern value="%folder\MyApp-" />
</file>
<param name="AppendToFile" value="true" />
<param name="StaticLogFileName" value="false" />
<param name="DatePattern" value="yyyy-MM-dd-hh-mm-ss.lo\g" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%d %-5p %m%n" />
</layout>
</appender>
<logger name="MyApp">
<level value="DEBUG" />
<maximumFileSize value="10MB" />
<appender-ref ref="MainApplication" />
</logger>
</log4net>
</configuration>
感谢您的建议。
答案 0 :(得分:2)
当您阅读配置时,Log4net将创建一个新的文件名。如果你看到多个日志文件,我的通灵调试功能告诉我你在执行时调用log4net配置更多。或者文件超过10mb,如您所配置:
<maximumFileSize value="10MB" />