关于最新版本的log4net使用中遇到的问题

Quartz.NET是一个开源的作业调度框架,是OpenSymphony 的 Quartz API的.NET移植,它用C#写成,可用于winform和asp.net应用中。它提供了巨大的灵活性而不牺牲简单性。你能够用它来为执行一个作业而创建简单的或复杂的调度。它有很多特征,如:数据库支持,集群,插件,支持cron-like表达式等等。

它的下载地址:http://sourceforge.net/projects/quartznet/files/quartznet/

我们下载了最新版本后,发现它使用的Common.Logging.dll \Common.Logging.Core这二个dll是3.0.0.0版本的,这二个dll是什么作用呢,我简要概述一下

Common.Logging.dll 通用日志接口

Common.Logging.Core 包含 Common.Logging 低级抽象常见到其他所有的 Common.Logging 软件包的便携式 (PCL) 实现。(通俗的讲就是帮你实现了读取配置文件实现你想要的log,比如你想用log4net,直接在配置文件中配置一下,就可以直接在项目中使用,具体的实现由它来帮你完成)。

接下来我们是使用log4net作为日志,这里不要下载最新的版本,因为Common.Logging的版本限制了你使用最新的。这中间为了让你少走弯路,你直接用程序包管理控制台,输入

PM>Install-Package Common.Logging.Log4Net1211 -Version 3.0.0,然后程序会自动安装,包括log4net也会找到适应的版本进行安装,如果你不是这样做,会出现各种各样的问题,最常见的问题是Failed obtaining configuration for Common.Logging from configuration。这个问题一是因为版本不正确,二是因为配置文件,你的配置文件要对应你的dll名称。

接着配置文件配置一下,就可以实现我们想要的日志管理了。建议大家直接在工具→Nuget程序包管理器→程序包管理器中→输入Install-Package Common.Logging.Log4Net1211 -Version 3.0.0,这样做的好处是你不用在担心各个组件之间的版本问题。最后我把配置文件贴一下。

<?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>
  <log4net>
    <root>
      <!--控制级别,由低到高: ALL|DEBUG|INFO|WARN|ERROR|FATAL|OFF-->
      <!--比如定义级别为INFO,则INFO级别向下的级别,比如DEBUG日志将不会被记录-->
      <!--如果没有定义LEVEL的值,则缺省为DEBUG-->
      <level value="ALL" />
      <appender-ref ref="InfoFileAppender" />
      <appender-ref ref="RollingFileAppender" />
      <appender-ref ref="ConsoleAppender" />
    </root>
    <appender name="InfoFileAppender" type="log4net.Appender.RollingFileAppender">
      <file value="log/" />
      <appendToFile value="true" />
      <param name="DatePattern" value="yyyyMMdd&quot;.txt&quot;" />
      <rollingStyle value="Date" />
      <maxSizeRollBackups value="100" />
      <maximumFileSize value="1024KB" />
      <staticLogFileName value="false" />
      <Encoding value="UTF-8" />
      <filter type="log4net.Filter.LevelRangeFilter">
        <param name="LevelMin" value="INFO" />
        <param name="LevelMax" value="INFO" />
      </filter>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date %-5level %logger  - %message%newline" />
      </layout>
    </appender>
    <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <file value="Log/" />
      <appendToFile value="true" />
      <rollingStyle value="Date" />
      <!--<datePattern value="yyyyMMdd-HHmm" />-->
      <datePattern value="yyyyMMdd" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread](%file:%line) %-5level %logger [%property{NDC}] - %message%newline" />
      </layout>
    </appender>
    <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
      </layout>

    </appender>
  </log4net>
  <common>
    <logging>
      <factoryAdapter type="Common.Logging.Log4Net.Log4NetLoggerFactoryAdapter, Common.Logging.Log4net1211">
        <arg key="configType" value="INLINE" />
        <!-- FILE,FILE-WATCH,INLINE,EXTERNAL 如果要是file 需要指定configFile -->
        <!--<arg key="configFile" value="~/Log4NET.xml"/>-->
      </factoryAdapter>
    </logging>
  </common>
  <startup>
    <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
  </startup>
</configuration>

最后附几个问题,第一个是Failed obtaining configuration for Common.Logging from configuration section 'common/logging'.出现这个问题是因为Common.Logging.Log4net,你需要把它改为Common.Logging.Log4net1211。第二个问题就是说版本不一致,一般是指loger4net,你看一下你的debug文件夹下的版本,因为你使用了nuget,但是编译后的文件可能没有替换。

posted @ 2015-11-16 15:32  生有涯而知无涯  阅读(2513)  评论(1编辑  收藏  举报