Log4net 没有在日志文件中写入任何内容
Log4net is not writing anything in log files
我正在使用 C#、.NET Framework 4.7 和 log4net 2.08 开发 Windows 服务应用程序。
我的问题是 log4net 没有记录任何内容。它只创建文件,没有别的。
这是我的配置文件(app.config):
<log4net>
<appender type="log4net.Appender.RollingFileAppender" name="ERPErrorAppender">
<file value="D:\MyCompany\Logs\ERP_Service.Error.log" />
<appendToFile value="true" />
<rollingStyle value="Date" />
<datePattern value=".yyyyMMdd.lo\g" />
<maximumFileSize value="5MB" />
<maxSizeRollBackups value="-1" />
<countDirection value="1" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date %-5level [%thread] %logger - %message%newline%exception" />
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<levelMin value="WARN" />
<levelMax value="ERROR" />
</filter>
</appender>
<appender type="log4net.Appender.RollingFileAppender" name="ERPDebugAppender">
<file value="D:\MyCompany\Logs\ERP_Service.Debug.log" />
<appendToFile value="true" />
<rollingStyle value="Date" />
<datePattern value=".yyyyMMdd.lo\g" />
<maximumFileSize value="5MB" />
<maxSizeRollBackups value="-1" />
<countDirection value="1" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date %-5level [%thread] %logger - %message%newline%exception" />
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<levelMin value="DEBUG" />
<levelMax value="INFO" />
</filter>
</appender>
<logger name="ERPService_Error">
<level value="ERROR" />
<appender-ref ref="ERPErrorAppender" />
</logger>
<logger name="ERPService_Debug">
<level value="DEBUG" />
<appender-ref ref="ERPDebugAppender" />
</logger>
</log4net>
以及Program.cs中的内容:
static class Program
{
private static readonly log4net.ILog log =
log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
以及我的ServiceBase中的内容class:
public partial class ERPWindowsService : ServiceBase
{
private static readonly ILog _log =
LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
当我在我的 ServiceBase 中捕获异常时 class:
catch (Exception ex)
{
_log.Error(ex);
this.Stop();
}
当我停止服务时(我在 OnStart
上做同样的事情):
protected override void OnStop()
{
_log.Debug("OnStop");
// Stop timer and dispose it.
if (_timer != null)
{
try
{
_timer.Stop();
_timer.Dispose();
}
catch (Exception ex)
{
_log.Error(ex);
}
}
}
为什么它没有在文件上写任何东西?
我已经重新启动了服务,但日志文件仍然是空的。
j.v。在你的评论是正确的。如果您在 AssemblyInfo.cs 文件中配置记录器,请确保它指向正确的 xml 配置文件(在您的情况下 app.config)。
或者您可以致电
log4net.Config.XmlConfigurator.Configure();
或您的 program.cs 文件中的 overloads 之一。
这个 thread 可能会提供更多解释。
您提到日志文件已创建,这意味着配置已成功加载。
因为您没有配置 root
记录器(这样做是有效的),而只配置了命名记录器,您必须确保配置的名称与给 ILog
个实例的匹配。
这是错误的地方。
您的 ILog
实例通过从下面一行返回的类型命名。
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType)
这将是 Type
的 FullName
,包括它的 namespace
。
对于 class Program
这将是 YourNamespace.Program
。
对于 class ERPWindowsService
,这将是 YourNamespace.ERPWindowsService
。
您必须在 Log4net
配置中使用这些全名。
<logger name="YourNamespace.ERPWindowsService">
<level value="DEBUG" />
<appender-ref ref="ERPDebugAppender" />
</logger>
因为没有配置root
记录器,所以必须为每个ILog
实例配置一个显式记录器;这里是 class Program
.
<logger name="YourNamespace.Program">
<!-- .... -->
</logger>
或者,您可以为 ILog
实例分配显式名称,例如:
log4net.ILog log = log4net.LogManager.GetLogger("ERPService_Error");
以匹配您当前的 Log4net
配置。
<logger name="ERPService_Error">
我正在使用 C#、.NET Framework 4.7 和 log4net 2.08 开发 Windows 服务应用程序。
我的问题是 log4net 没有记录任何内容。它只创建文件,没有别的。
这是我的配置文件(app.config):
<log4net>
<appender type="log4net.Appender.RollingFileAppender" name="ERPErrorAppender">
<file value="D:\MyCompany\Logs\ERP_Service.Error.log" />
<appendToFile value="true" />
<rollingStyle value="Date" />
<datePattern value=".yyyyMMdd.lo\g" />
<maximumFileSize value="5MB" />
<maxSizeRollBackups value="-1" />
<countDirection value="1" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date %-5level [%thread] %logger - %message%newline%exception" />
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<levelMin value="WARN" />
<levelMax value="ERROR" />
</filter>
</appender>
<appender type="log4net.Appender.RollingFileAppender" name="ERPDebugAppender">
<file value="D:\MyCompany\Logs\ERP_Service.Debug.log" />
<appendToFile value="true" />
<rollingStyle value="Date" />
<datePattern value=".yyyyMMdd.lo\g" />
<maximumFileSize value="5MB" />
<maxSizeRollBackups value="-1" />
<countDirection value="1" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date %-5level [%thread] %logger - %message%newline%exception" />
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<levelMin value="DEBUG" />
<levelMax value="INFO" />
</filter>
</appender>
<logger name="ERPService_Error">
<level value="ERROR" />
<appender-ref ref="ERPErrorAppender" />
</logger>
<logger name="ERPService_Debug">
<level value="DEBUG" />
<appender-ref ref="ERPDebugAppender" />
</logger>
</log4net>
以及Program.cs中的内容:
static class Program
{
private static readonly log4net.ILog log =
log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
以及我的ServiceBase中的内容class:
public partial class ERPWindowsService : ServiceBase
{
private static readonly ILog _log =
LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
当我在我的 ServiceBase 中捕获异常时 class:
catch (Exception ex)
{
_log.Error(ex);
this.Stop();
}
当我停止服务时(我在 OnStart
上做同样的事情):
protected override void OnStop()
{
_log.Debug("OnStop");
// Stop timer and dispose it.
if (_timer != null)
{
try
{
_timer.Stop();
_timer.Dispose();
}
catch (Exception ex)
{
_log.Error(ex);
}
}
}
为什么它没有在文件上写任何东西?
我已经重新启动了服务,但日志文件仍然是空的。
j.v。在你的评论是正确的。如果您在 AssemblyInfo.cs 文件中配置记录器,请确保它指向正确的 xml 配置文件(在您的情况下 app.config)。
或者您可以致电
log4net.Config.XmlConfigurator.Configure();
或您的 program.cs 文件中的 overloads 之一。
这个 thread 可能会提供更多解释。
您提到日志文件已创建,这意味着配置已成功加载。
因为您没有配置 root
记录器(这样做是有效的),而只配置了命名记录器,您必须确保配置的名称与给 ILog
个实例的匹配。
这是错误的地方。
您的 ILog
实例通过从下面一行返回的类型命名。
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType)
这将是 Type
的 FullName
,包括它的 namespace
。
对于 class Program
这将是 YourNamespace.Program
。
对于 class ERPWindowsService
,这将是 YourNamespace.ERPWindowsService
。
您必须在 Log4net
配置中使用这些全名。
<logger name="YourNamespace.ERPWindowsService">
<level value="DEBUG" />
<appender-ref ref="ERPDebugAppender" />
</logger>
因为没有配置root
记录器,所以必须为每个ILog
实例配置一个显式记录器;这里是 class Program
.
<logger name="YourNamespace.Program">
<!-- .... -->
</logger>
或者,您可以为 ILog
实例分配显式名称,例如:
log4net.ILog log = log4net.LogManager.GetLogger("ERPService_Error");
以匹配您当前的 Log4net
配置。
<logger name="ERPService_Error">