【问题标题】:Log4net is not writing anything in log filesLog4net 没有在日志文件中写入任何内容
【发布时间】:2018-07-20 08:53:03
【问题描述】:

我正在使用 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 类中的内容:

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

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

我已经重启了服务,日志文件还是空的。

【问题讨论】:

  • 您是否添加了除异常处理程序之外的任何日志记录?您是否对其进行了调试以尝试检查您是否确实在记录某条记录的行?我会添加一行来记录“开始”消息只是为了检查...
  • 是的,我已经完成了所有这些。请查看我更新的问题。
  • 搜索这一行 [assembly: log4net.Config.XmlConfigurator(ConfigFile = "Log4net.config", Watch = true)] 并检查它是否与您的 log4net 配置文件的名称匹配
  • 您缺少根记录器。支持吗?
  • @j.v.我在很多项目中都使用了 log4net,但我没有使用它。

标签: c# .net windows-services log4net


【解决方案1】:

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

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

这就是问题所在。

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

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

这将是TypeFullName,包括它的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">

【讨论】:

    【解决方案2】:

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

    您也可以调用

    log4net.Config.XmlConfigurator.Configure();
    

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

    这个thread 可能会提供更多解释。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2023-03-31
      • 2016-05-08
      • 2012-11-11
      • 1970-01-01
      • 1970-01-01
      • 2018-06-24
      • 1970-01-01
      相关资源
      最近更新 更多