部署时Log4Net不记录

时间:2013-06-13 15:55:56

标签: c# .net log4net

使用版本1.2.11。日志记录在我的开发机器上运行,但在部署时不会创建目录或日志。

我试过了:

  • 提供对IUSR,Everyone,本地用户的完整目录访问。
  • 将应用池作为本地管理员帐户运行。
  • 将内部调试用作Phil Haack describes here

每次更改后停止并启动应用程序池。

输出文件中没有任何内容。

我的log4Net配置如下。关于下一步该尝试的任何想法?

<?xml version="1.0"?>
<log4net debug="true">
  <appender name="file" type="log4net.Appender.RollingFileAppender">
    <file value="..\Logging\log.txt" />
    <appendToFile value="true" />
    <rollingStyle value="Composite" />
    <datePattern value="yyyyMMdd" />
    <maxSizeRollBackups value="10" />
    <maximumFileSize value="1MB" />
    <threshold value="DEBUG" />
    <layout type="log4net.Layout.PatternLayout">
      <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
    </layout>
  </appender>
  <appender name="console" type="log4net.Appender.DebugAppender">
    <layout type="log4net.Layout.PatternLayout">
      <param name="ConversionPattern" value="%d [%t] %-5p %c [%x] &lt;%X{auth}&gt; - %m%n" />
    </layout>
  </appender>
  <root>
    <level value="ALL" />
    <appender-ref ref="file" />
    <appender-ref ref="console" />
  </root>
</log4net>

5 个答案:

答案 0 :(得分:6)

如果没有创建目录和文件,那么很可能是在运行时没有读取(因此使用)配置。

我总是忘记为Log4net添加连接配置的单行代码。此代码通常出现在应用程序的bootstrap类中(例如,ASP.NET应用程序的Global.asax)。

XmlConfigurator.Configure(new System.IO.FileInfo(configFile));  // configFile being the path to the file.

您可以将此属性添加到AssemblyInfo.cs文件中,而不是上面的内联:

[assembly: log4net.Config.XmlConfigurator(Watch = true)]

无论哪种方式,这将连接log4net。更多信息可在Manual Configuration section of the log4net docs

中找到

答案 1 :(得分:3)

听起来像是权限问题。我几乎总是使用一个目录,我没有为应用程序启用任何特殊权限来写日志文件。

以下是我通常用于log4net的内容:

<file type="log4net.Util.PatternString" value="${ALLUSERSPROFILE}/<Company Name>/Logs/<Program Name>/<Log file name>.txt" />

对于cource,您需要使用实际值替换上面的公司名称,程序名称和日志文件名称。

这将写入ProgramData文件夹,其中访问通常不受限制。您可以通过键入%ProgramData%或%AllUsersProfile%

在文件资源管理器中导航到此文件夹

我喜欢这种方法的另一件事是它几乎适用于所有的微软操作系统。 XP,Vista,7,8

答案 2 :(得分:2)

您可能不知道您在哪里记录:

<file value="..\Logging\log.txt" />

Will派生自您正在运行的目录,即iis的目录。您可以更好地使用完整路径,如:

<file value="c:\Logging\log.txt" />

然后,您可以为日志记录目录授予正确的访问权限。据我所知,Log4net不会创建任何目录。所以你必须先创建c:\ logging目录。

答案 3 :(得分:1)

如果您正在使用IIS,请确保正确的组具有对Logs文件夹(通常是IIS_USERS)的修改权限。

答案 4 :(得分:0)

在我将这些行添加到web.config应用程序设置之前,没有任何答案对我有用:

<add key="log4net.Config" value="Log.config" />
<add key="log4net.Config.Watch" value="True" />