zoukankan      html  css  js  c++  java
  • log4net的配置详解

     log4net是一款优秀的第三方日志框架,可以很容易的加载到开发项目中(引用log4net的dll,再配置些基本参数即可),帮助程序员把日志信息输出到各种不同的目标,常见的有文本、数据库、windows日志、邮件、内存缓冲区等目标。

    首先需要log4net的dll(源码中dll版本是1.2.10.0),引用到程序中,然后再配置下配置文件,配置文件如下:

    <?xml version="1.0"?>
    <configuration>
      <configSections>
        <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="ERROR"/>
          <appender-ref ref="RollingFileAppender"/>
        </root>
        <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
          <!--日志文件名开头-->
          <file value="c:LogTestLog4net.TXT"/>
          <!--多线程时采用最小锁定-->
          <lockingModel type="log4net.Appender.FileAppender+MinimalLock"/>
          <!--日期的格式,每天换一个文件记录,如不设置则永远只记录一天的日志,需设置-->
          <datePattern value="(yyyyMMdd)"/>
          <!--是否追加到文件,默认为true,通常无需设置-->
          <appendToFile value="true"/>
          <!--变换的形式为日期,这种情况下每天只有一个日志-->
          <!--此时MaxSizeRollBackups和maximumFileSize的节点设置没有意义-->
          <!--<rollingStyle value="Date"/>-->
          <!--变换的形式为日志大小-->
          <!--这种情况下MaxSizeRollBackups和maximumFileSize的节点设置才有意义-->
          <RollingStyle value="Size"/>
          <!--每天记录的日志文件个数,与maximumFileSize配合使用-->
          <MaxSizeRollBackups value="10"/>
          <!--每个日志文件的最大大小-->
          <!--可用的单位:KB|MB|GB-->
          <!--不要使用小数,否则会一直写入当前日志-->
          <maximumFileSize value="2MB"/>
          <!--日志格式-->
          <layout type="log4net.Layout.PatternLayout">
            <conversionPattern value="%date [%t]%-5p %c - %m%n"/>
          </layout>
        </appender>
      </log4net>
    </configuration>

    然后代码如下:

    using System;
    using System.Reflection;
    using log4net;
    using log4net.Config;
    namespace Log4Net1001
    {
        class Program
        {
            static void Main(string[] args)
            {
                Console.WriteLine("Begin Run");
                XmlConfigurator.Configure();
                Type type = MethodBase.GetCurrentMethod().DeclaringType;
                ILog m_log = LogManager.GetLogger(type);
                m_log.Debug("这是一个Debug日志");
                m_log.Info("这是一个Info日志");
                m_log.Warn("这是一个Warn日志");
                m_log.Error("这是一个Error日志");
                m_log.Fatal("这是一个Fatal日志");
                Console.WriteLine("End");
                Console.ReadLine();
            }
        }
    }

    如果是网站项目,须在项目中的AssemblyInfo.cs文件的最后一行中添加:

    [assembly: log4net.Config.DOMConfigurator(ConfigFile = "Web.config", Watch = true)] 
  • 相关阅读:
    Java上等价类划分测试的实现
    软件测试の因果图法的测试运用
    display: block; 和 display: inline; 的区别
    CSS实现垂直居中
    CSS中实现水平居中
    HTTP头部信息
    HTTP PUT方法和POST方法的区别
    理解 ajax xhr jsonp
    深入理解JavaScript系列
    Angular 1.x 指令笔记
  • 原文地址:https://www.cnblogs.com/wolfocme110/p/4455474.html
Copyright © 2011-2022 走看看