11

我想将日志记录功能实现到一个类库中,该类库本身在 Web 服务中被引用。我试图添加 app.config 并做了所有需要的事情,但似乎当抛出异常时,log4net 什么也不做。

我的 app.config

<configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
  </configSections>
  <log4net>
    <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <file value="D:\\mylogfile.txt" />
      <appendToFile value="true" />
      <rollingStyle value="Size" />
      <maxSizeRollBackups value="5" />
      <maximumFileSize value="10MB" />
      <staticLogFileName value="true" />
      <filter type="log4net.Filter.StringMatchFilter">
        <stringToMatch value="test" />
      </filter>
      <filter type="log4net.Filter.StringMatchFilter">
        <stringToMatch value="error" />
      </filter>
      <filter type="log4net.Filter.DenyAllFilter" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %level %logger - %message%newline%exception" />
      </layout>
    </appender>
    <root>
      <level value="INFO"/>
      <appender-ref ref="RollingFileAppender"/>
      <appender-ref ref="ConsoleAppender" />
    </root>
  </log4net>

在 AssemblyInfo.cs 中:

[assembly: log4net.Config.XmlConfigurator(ConfigFile = "app.config")]

在 LogManager.cs 中:

private static readonly ILog Log = log4net.LogManager.GetLogger
            (MethodBase.GetCurrentMethod().DeclaringType);
public static void WriteLog(Exception ex)
{
    Log.Error(ex);
}

你能告诉我有什么问题吗?如何让 log4net 为我的类库工作?

谢谢

4

3 回答 3

7

在运行时,除非明确声明,否则始终从主机应用程序使用配置文件。以防万一,使用的是 web.config 而不是 app.cofig。而是提及一些其他自定义配置文件名,并确保将该文件复制到 Web 服务的虚拟目录中。也正如 chibacity 所说,确保日志文件的权限。最好将其保存在 web 服务主机的 app_data 文件夹中。

于 2011-01-06T08:06:59.593 回答
4

您可以使用某种注入,或者构建一个简单的注入,例如:

public interface ILogger
{
    void LogInfo(string message);
       .
       .
       .
}

然后你只需注入与该接口匹配的东西,比如 log4net 的包装器等。

但是,我认为最正确的做法是不登录类库。为什么我这么认为是因为图书馆本身不是应用程序,你的网络服务是你的网络服务应该决定记录什么。如果您想记录异常,请不要在类库中捕获它们并让您的 Web 服务处理日志记录。这也将使集中日志记录变得更加容易。

于 2011-01-06T08:23:57.380 回答
1

请看我对以下问题的回答:

在 SDK 中使用 log4net

它有一个日志配置例程,它将构建一个 log4net 配置文件的完整路径。当您在网络服务中时,我不会在您期望的“app.config”中寻找。

还要确保您有权从您的网络服务写入“D:\mylogfile.txt”。

于 2011-01-06T07:57:41.453 回答