我们正在使用log4net,并希望在外部配置文件中指定它的配置(就像我们对其他部分所做的那样)。为此,我们将App.config中的log4net部分更改为:
...
<section name="log4net"
type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
...
<log4net configSource="Log.config" />
...
在Log.Config文件(与App.config相同的目录)中,我们有:
<log4net>
<appender name="General" type="log4net.Appender.FileAppender">
<file value="myapp.log" />
<layout type="log4net.Layout.SimpleLayout" />
</appender>
<root>
<appender-ref ref="General" />
</root>
</log4net>
但是,当我们运行应用程序时,不会创建日志文件(也不会进行日志记录)。没有错误消息输出到控制台。
如果我们将Log.config文件的内容移回App.config (替换上面的第一行代码),它将按预期工作。你知道为什么它不能在外部文件中工作吗?
发布于 2009-01-15 00:11:00
您的AssemblyInfo.cs
文件中是否具有以下属性:
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "Log4Net.config", Watch = true)]
并在需要日志记录功能的每个类的开头编写如下代码:
private static readonly ILog log =
LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
我有一个博客帖子,其中包含这个和其他信息here。
发布于 2009-09-25 12:10:16
在这个问题上有一个open defect。Log4Net不支持配置元素的configSource属性。要使用纯配置文件解决方案,您可以在appSettings中使用log4net.Config键。
第1步:包含普通配置节定义:
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
</configSections>
步骤2:在appSettings中使用神奇的log4net.Config密钥。
<appSettings>
<add key="log4net.Config" value="log4net.simple.config" />
</appSettings>
步骤3:贡献一个补丁来修复configSource的处理。
发布于 2011-04-11 21:09:41
遗漏的一步是
log4net.Config.XmlConfigurator.Configure();
这将导致使用configSource。确保在调用GetLogger()之前调用它一次;
https://stackoverflow.com/questions/445976
复制