log4net没有输出
本文关键字:输出 log4net | 更新日期: 2023-09-27 17:57:34
我正在尝试使用log4net,方法是遵循一些教程,阅读大量关于人们使用它有问题的帖子,因为我无法使它正常工作。
我把这个部分放在我的.config
文件的顶部
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
</configSections>
<log4net>
<appender name="RollingFile" type="log4net.Appender.RollingFileAppender">
<file value="log4net.log" />
<appendToFile value="true" />
<maximumFileSize value="500KB" />
<maxSizeRollBackups value="2" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date %level %logger - %message%newline" />
</layout>
</appender>
<root>
<level value="All" />
<appender-ref ref="RollingFile" />
</root>
</log4net>
我在AssemblyInfo文件中添加了这一行
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "Web.config", Watch = true)]
并尝试在像这样的mt服务中使用记录器
private static readonly log4net.ILog log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
或
private static ILog Log = LogManager.GetLogger(typeof(MyService));
但从未创建过任何文件,也没有任何其他迹象表明正在发生什么。
如何正确使用此记录器?
创建一个log4net DebugAppender以在Visual Studio输出窗口中查看log4net的输出,这应该会为您提供一些问题指示。
添加到app.config:
<appSettings>
<!-- log4net configuration when running in debug mode. -->
<add key="log4net.Internal.Debug" value="true" />
</appSettings>
在log4net.config:中添加一个新的调试附加程序
<appender name="DebugAppender" type="log4net.Appender.DebugAppender">
<immediateFlush value="true" />
<layout type="log4net.Layout.SimpleLayout" />
</appender>
并将新的appender添加到log4net.config根目录:
<root>
<level value="ALL" />
<appender-ref ref="RollingFile" />
<appender-ref ref="DebugAppender" />
</root>
运行应用程序并查看Visual Studio输出窗口,以查看log4net的内部日志记录。如果没有输出,则永远不会加载log4net.config文件。