Log4net没有在日志文件中写入任何内容

时间:2018-07-20 08:53:03

标签: c# .net windows-services log4net

我正在使用C#、. NET Framework 4.7和log4net 2.08开发Windows Service应用程序。

我的问题是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类中的内容:

public partial class ERPWindowsService : ServiceBase
{
    private static readonly ILog _log =
        LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);

当我在ServiceBase类中捕获异常时:

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);
        }
    }
}

为什么它没有在文件上写任何东西?

我已经重新启动了服务,日志文件仍然为空。

2 个答案:

答案 0 :(得分:2)

您提到创建了日志文件,这意味着配置已成功加载。

由于您尚未配置root记录器(是有效的),而仅配置了命名记录器,因此必须确保配置的名称与给定的名称匹配到ILog实例。

这就是问题所在。

您的ILog实例通过下面一行返回的类型命名。

System.Reflection.MethodBase.GetCurrentMethod().DeclaringType)

这将是FullName的{​​{1}},包括其Type

对于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

答案 1 :(得分:0)

j.v。在您的评论中是正确的。确保如果要在AssemblyInfo.cs文件中配置记录器,请确保它指向正确的xml配置文件(在您的情况下为app.config)。

或者您可以致电

log4net.Config.XmlConfigurator.Configure();

或者是您program.cs文件中的overloads之一。

thread可能会提供更多说明。