部署时Log4Net不记录

Phi*_*ler 7 .net c# log4net

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

我试过了:

  • 提供对IUSR,Everyone,本地用户的完整目录访问权限.
  • 将应用程序池作为本地管理员帐户运行.
  • Phil Haack所述,使用内部调试.

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

输出文件中没有生成任何内容.

我的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>
Run Code Online (Sandbox Code Playgroud)

Dav*_*yon 7

如果未创建目录和文件,则很可能在运行时未读取(因此使用)配置.

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

XmlConfigurator.Configure(new System.IO.FileInfo(configFile));  // configFile being the path to the file.
Run Code Online (Sandbox Code Playgroud)

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

[assembly: log4net.Config.XmlConfigurator(Watch = true)]
Run Code Online (Sandbox Code Playgroud)

无论哪种方式,这将连接log4net.有关详细信息,请参见log4net文档的" 手动配置"部分.

  • 我不确定这是如何解释他在开发环境中能够记录的. (8认同)
  • 我在这一个人的墙上撞了一会儿.我尝试使用AssemblyInfo.cs方法,这在我的本地开发盒上工作,但在服务器上没有.一旦我将"XmlConfigurator.Configure();"行添加到Global.asax.cs文件中,它就可以了! (2认同)
  • 与 @JebaDaHut 相同 - 它正在使用 AssemblyInfo.cs 行在我的开发计算机上运行,​​但在部署时不起作用。添加“XmlConfigurator.ConfigureAndWatch(new FileInfo(....))”后,它开始登录我的部署服务器。 (2认同)

Bac*_*ave 6

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