我的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类记录
Logger.Log.Info("User visits Sign In Page.");
设置上述设置时,记录功能一直有效。但突然伐木已停止工作。 但是当我使用上述设置创建一个新的asp.net mvc网站时,日志记录就可以了。 我试过IIS Express和本地IIS。在这两种情况下,记录都适用于我创建的测试应用程序。
我无法弄清楚为什么它没有记录?我怎么诊断这个?有什么可能的问题?
答案 0 :(得分:13)
由我自己解决,原因是“由于某种原因”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)]
答案 1 :(得分:2)
原因是Log4Net尝试从首次使用LogManager.GetLogger()
的程序集加载配置。如果它是您的一个类库,它将忽略所有其他程序集中的属性。
最简单的解决方法是在您的初始文件中调用LogManager
(例如Program.cs
或Global.asax
):
var logger = LogManager.GetLogger(typeof(Program));
logger.Info("Application started.");
//rest of app init.
这样做可以使用程序集属性获得预期的行为。
答案 2 :(得分:1)
我发现log4net不会加载webconfig配置,除非你调用log4net.Config.XmlConfigurator.Configure();在启动时。
protected void Application_Start()
{
// your other codes
log4net.Config.XmlConfigurator.Configure(); // must have this line
Logger = log4net.LogManager.GetLogger(typeof(MvcApplication));
}
答案 3 :(得分:0)
我有一个类似的问题:从IIS或IISExpress运行程序集时,不会得到任何日志记录输出。
但是,以上所有答案对我都没有作用。
在我的情况下,解决方案是将配置文件的路径指定为绝对路径。事实证明,IISExpress不会将当前目录设置为bin文件夹,log4net找不到配置文件,因此我不得不使用以下解决方法:
string codeBase = Assembly.GetExecutingAssembly().CodeBase;
// remove file:// part from uri
UriBuilder ub = new UriBuilder(codeBase);
string path = Uri.UnescapeDataString(ub.Path);
var fi = new FileInfo(Path.Combine(Path.GetDirectoryName(path), "Logging.config.xml"));
if (fi.Exists)
{
log4net.Config.XmlConfigurator.ConfigureAndWatch(fi);
var logger = log4net.LogManager.GetLogger(typeof(WebApiApplication));
logger.Info("Application started.");
}
else
{
throw new FileNotFoundException("log4net config file not found", fi.FullName);
}