我已经为我的应用程序实现了记录器,并且我想在.NET Core Console Application上以XML格式(XmlLayout)记录活动。 Log4Net配置包括FileAppender和XmlFileAppender,如下所示。Log4Net Layout.XmlLayout不会在.NET核心平台中创建日志
<log4net>
<appender name="FileAppender" type="log4net.Appender.FileAppender">
<file value="C:\Log4NetLogs\UaGatewayText.log.txt"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="[%date{dd.MM.yyyy}] [%date{ABSOLUTE}] [%thread]
%level %property{TEST - Ua.Gateway} %message%newline" />
</layout>
</appender>
<appender name="ConsolAppender"
type="log4net.Appender.ConsoleAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="[%dae{DATE}] [%date{ABSOLUTE}] [%thread]
[%level] %message%newline" />
</layout>
</appender>
<appender name="XmlFileAppender"
type="log4net.Appender.RollingFileAppender">
<file type="log4net.Util.PatternString"
value="C:\Log4NetLogs\UaGatewayXml.log.xml" />
<appendToFile value= "true" />
<rollingStyle value="size"/>
<maximumFileSize value ="50MB"/>
<maxSizeRollBackups value ="10"/>
<layout type="log4net.Layout.XmlLayout" />
</appender>
<root>
<level value="ALL" />
<appender-ref ref="FileAppender" />
<appender-ref ref="XmlFileAppender" />
</root>
</log4net>
在.NET核心控制台应用程序,XmlAppender在目录中创建UaGatewayXml.log.xml文件,不写任何日志。但是,它对FileAppender非常有用。
对于XmlFileAppender和FileAppender,上述配置对.NET Framework(4.5。*)均按预期工作。
我必须在配置文件中进行任何更改吗? 由于
你有[看了一下log4net的调试输出(http://haacked.com/archive/2006/09/27/Log4Net_Troubleshooting.aspx /)? – stuartd
我以前见过。 .NET Core项目不包含App.config文件,所以我不能这样做。 – JayeshThamke
这只是一种启用调试的方法 - 您也可以在log4net配置中使用',或者您可以在代码中使用'log4net.Util.LogLog.InternalDebugging = true;' –
stuartd