我正在尝试将Quartz 2.1.2与日志记录一起使用,但在调试时我不断收到以下输出:
未找到配置部分 - 禁止记录输出
这是我的App.config文件:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<sectionGroup name="common">
<section name="logging" type="Common.Logging.ConfigurationSectionHandler, Common.Logging" />
</sectionGroup>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
</configSections>
<common>
<logging>
<factoryAdapter type="Common.Logging.Log4Net.Log4NetLoggerFactoryAdapter, Common.Logging.Log4Net">
<arg key="configType" value="INLINE"/>
<arg key="configFile" value="c:\Scheduler.log"/>
<arg key="level" value="INFO" />
</factoryAdapter>
</logging>
</common>
<log4net>
<appender name="EventLogAppender" type="log4net.Appender.EventLogAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%d [%t] %-5p %l - %m%n" />
</layout>
</appender>
<root>
<level value="INFO" />
<appender-ref ref="EventLogAppender" />
</root>
</log4net>
</configuration>
这是实例化我的调度程序的代码:
private IScheduler scheduler;
public JobScheduler()
{
ISchedulerFactory schedulerFactory = new StdSchedulerFactory();
this.scheduler = schedulerFactory.GetScheduler();
this.scheduler.Start();
}
我究竟做错了什么?
更新:
好的,所以我做错的一件事是我的单元测试项目中没有包含 App.config 文件。一旦我这样做了,我得到了一个不同的错误:
无法创建类型“Common.Logging.Log4Net.Log4NetLoggerFactoryAdapter,Common.Logging.Log4Net”
我没有在 Common.Logging 命名空间中看到 Log4Net,所以我通过包管理器添加了 DLL,但我仍然得到同样的错误。我正在使用 Common.Logging 2.1.2 版。任何想法为什么我仍然有问题?