大家早上好,
我有一个log4net问题,当我在我的网站上进行开发时,该问题并不存在 本地计算机,但是一旦我将应用程序部署到服务器,log4net就停止了工作。
这是服务器配置: -Windows XP SP3 -IIS 7 -framework .Net v4
这是网站web.config中的log4net配置:
<configuration>
<log4net>
<root>
<level value="DEBUG" />
<appender-ref ref="LogFileAppender" />
</root>
<appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
<param name="File" value="log.txt" />
<param name="AppendToFile" value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="10" />
<maximumFileSize value="30MB" />
<staticLogFileName value="false" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%-5p%d{yyyy-MM-dd hh:mm:ss} – %m%n" />
</layout>
</appender>
</log4net>
</configuration>
我还有一个类库,这是它的App.config文件:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,Log4net"/>
</configSections>
<log4net>
<root>
<level value="DEBUG" />
<appender-ref ref="LogFileAppender" />
</root>
<appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender" >
<param name="File" value="log.txt" />
<param name="AppendToFile" value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="10" />
<maximumFileSize value="30MB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%-5p%d{yyyy-MM-dd hh:mm:ss} – %m%n" />
</layout>
</appender>
</log4net>
</configuration>
这就是我在每个类上调用log函数的方法:
private static readonly ILog log = LogManager.GetLogger(typeof(AppDomain));
......这就是我所说的:
log.Error("\n\t=>" + ex.GetBaseException().Message + "\n\r" + " @ " + Environment.StackTrace);
答案 0 :(得分:13)
可能是您没有权限写入'log.txt'文件。
我不知道当前目录是什么,但它不太可能是IIS可以写入的地方。
您需要在某处创建一个文件夹并授予IIS写入权限,我知道您需要授予对IIS_IUSRS组的访问权限,然后指定该文件的绝对路径。 e.g。
<param name="File" value="D:\Logs\log.txt" />
..使用您首选位置的路径。
答案 1 :(得分:9)
当谈到编写日志文件时,我倾向于不尝试将我的日志文件写入程序文件目录中的任何位置或任何虚拟目录中的任何内容,只是因为我之前遇到过安全问题。目前我正在使用类似以下内容的所有log4net日志文件:
<file type="log4net.Util.PatternString" value="${ALLUSERSPROFILE}/<Product Name>/Logs/<Program Name>/<Program Name>.log" />
${ALLUSERSPROFILE}
是上面的关键。此目录通常没有作为虚拟目录和程序文件目录的安全限制。我发现自从我使用这条路以来,我没有遇到任何麻烦。
此envrionment变量将您带到Windows Vista,7,8,Server 2008等中的ProgramData
目录。我认为XP会将您带到另一个地方,但仍然是一个具有宽松权限的目录。
请注意上面的日志声明:
log.Error("\n\t=>" + ex.GetBaseException().Message + "\n\r" + " @ " + Environment.StackTrace);
可缩短为:log.Error(ex);
除非必须格式化。但是如果你这样写它并使用pdbs部署你的二进制文件,你记录的例外将包含完整的堆栈跟踪和发生错误的行号。
日志文件也将无法创建。如果您确定您对log4net配置中指定的文件夹具有写访问权限,我建议您首先在log4net配置部分设置debug="true"
来启用log4net调试:
<log4net debug="true">
...
</log4net>
设置上述调试标志将告诉log4net通过Windows跟踪侦听器输出所有日志。要捕获此跟踪侦听器输出,您必须在app.config中添加如下部分:
<system.diagnostics>
<trace autoflush="true">
<listeners>
<add
name="textWriterTraceListener"
type="System.Diagnostics.TextWriterTraceListener"
initializeData="C:\tmp\log4net.txt" />
</listeners>
</trace>
</system.diagnostics>
确保app.config中上述跟踪侦听器配置中指定的路径存在,并且您对该文件夹具有写入权限!
答案 2 :(得分:0)
我自己遇到了同样的问题,结果发现我忘了为配置文件设置“Build Action”。因此,未部署 log4net.config 文件,这当然需要使应用程序写入日志文件。
答案 3 :(得分:0)
应该为日志文件夹目录授予运行IIS的权限。例如如果IIS作为网络服务运行,则在目录中添加网络服务帐户并授予其完全权限。
答案 4 :(得分:0)
参考web.config中的以下配置进行检查。如果一切正常,请使用应用程序池所有者检查inetpub子文件夹的写入权限。如果没有授予完全许可。
希望它能解决您的问题
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>
<log4net debug="true">
<appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
<file value="logs\log.txt" />
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="10" />
<maximumFileSize value="10MB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%-5p %d %5rms %-22.22c{1} %-18.18M - %m%n %newline--%newline" />
</layout>
</appender>
<root>
<level value="DEBUG" />
<appender-ref ref="RollingLogFileAppender" />
</root>
</log4net>