gpt4 book ai didi

asp.net-mvc - Log4net 日志记录不起作用 - asp.net mvc

转载 作者:行者123 更新时间:2023-12-02 05:19:05 29 4
gpt4 key购买 nike

我的log4net配置是这样的,

    <?xml version="1.0" encoding="utf-8" ?>
<log4netConfiguration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>
<appSettings>
<add key="log4net.Config" value="log4net.config" />
</appSettings>
<log4net>
<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
<file type="log4net.Util.PatternString" value="C:\my_logs/my_web_logs/my_log_%date{ddMMyyyy}.log" />
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="5" />
<maximumFileSize value="30MB" />
<datePattern value="yyyyMMdd" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%4t %d{ABSOLUTE} %-5p %m%n"/>
<!--<conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] – %message%newline" />-->
</layout>
</appender>
<root>
<level value="INFO" />
<appender-ref ref="RollingFileAppender" />
</root>
</log4net>
</log4netConfiguration>

我有一个 Logger 辅助类,

public static class Logger
{
private static readonly log4net.ILog log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);

public static log4net.ILog Log
{
get { return log; }
}
}

在我的程序集信息中,我有此条目,

// Configure log4net using the .config file 
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config", Watch = true)]

log4net.config是添加到Web项目中的配置文件。

在我使用记录器类记录的代码中,

Logger.Log.Info("User visits Sign In Page.");

当我设置上述设置时,日志记录一直在工作。但突然日志记录停止工作了。但是当我使用上述设置创建一个新的 asp.net mvc 网站时,日志记录就可以了。我尝试使用 IIS Express 和本地 IIS。在这两种情况下,日志记录都适用于我创建的测试应用程序。

我不明白为什么它没有记录?我该如何诊断这个问题?可能出现哪些问题?

最佳答案

我自己解决了,原因是“由于某种原因”log4net 配置没有从程序集信息中加载。我仍然不知道为什么会发生这种情况。

我尝试了不同帖子提出的许多修复方案。终于解决了这个问题。this post中提到的解决方案帮助我解决了这个问题。

我添加了以下配置,

    <!--These settings load the log4net configuration.-->
<add key="log4net.Config" value="log4net.config"/>
<add key="log4net.Config.Watch" value="True"/>

它开始记录!

然后我从程序集信息中删除了以下行,

// Configure log4net using the .config file 
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config", Watch = true)]

关于asp.net-mvc - Log4net 日志记录不起作用 - asp.net mvc,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21107698/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com