【发布时间】: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