log4net使用详解

log4net是Apache的一个功能著名的开源日志记录组件。利用log4net可以方便地将日志信息记录到文件、控制台、Windows事件日志和数据库(包括MS SQL Server, Access, Oracle9i,Oracle8i,DB2,SQLite)中。并且我们还可以记载控制要记载的日志级别,可以记载的日志类别包括:FATAL(致命错误)、ERROR(一般错误)、WARN(警告)、INFO(一般信息)、DEBUG(调试信息)。

组件库下载地址:incubating-log4net-1.2.10.zip;

第一:通过VS新建项目:C#--->windows---->控制台应用程序

第二:解压文件找到\bin\net\2.0\debug\log4net.dll,并将其添加到工程引用中。

第三:新建一个配置文件,文件名称为log4net.config,内容为

 

 

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="log4net" type="System.Configuration.IgnoreSectionHandler"/>
  </configSections>
  <appSettings>
  </appSettings>
  <log4net>
    <!--定义输出到文件中-->
    <appender name="LogFileAppender" type="log4net.Appender.FileAppender">
      <!--定义文件存放位置-->
      <file value="log4netfile.txt" />
      <appendToFile value="true" />
      <layout type="log4net.Layout.PatternLayout">
        <!--每条日志末尾的文字说明-->
        <footer value="by zhangsan" />
        <!--输出格式-->  
        <conversionPattern value="%date ThreadId:[%thread] Level:%-5level Class:%logger property:[%property{NDC}] - msgInfo:%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>
 
    <!--定义日志的输出媒介-->
    <root>
      <!--文件形式记录日志-->
      <appender-ref ref="LogFileAppender" />
      <!--控制台控制显示日志-->
      <appender-ref ref="ConsoleAppender" />
    </root>
  </log4net>
</configuration>

 

   并将文件拷贝到工程目录下面的bin\Release或bin\Debug下面。

第四:加载配置文件,在这里提供两种方式,

 

  1. 通过类AssemblyInfo.cs中加载,在该类中最后一行添加内容:                                                                                                          [assembly: log4net.Config.XmlConfigurator(ConfigFile="log4net.config",Watch = true)]
  2. 通过Main函数运行类Program.cs加载,在类的namespace上面添加内容:                                                                                         [assembly: log4net.Config.XmlConfigurator(ConfigFile="log4net.config",Watch = true)]
  3. 通过程序控制加载。如:
        {
            static void Main(string[] args)
            {
                log4net.Config.XmlConfigurator.Configure(new FileInfo("log4net.config"));
    
          
            }
        }

 第五:测试 using System;
using System.Collections.Generic;
using System.Text;
using log4net;
using System.Reflection;
using System.IO;

namespace log4netconsoledemo
{
    class Program
    {
         ILog log = log4net.LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
        static void Main(string[] args)
        {
        
            log.Error("error", new Exception("this is Exception log"));
         
            log.Fatal("fatal", new Exception("this is Fatal log"));
           
            log.Info("info信息.......................");
            /
            log.Debug("debug信息.............................");
           
            log.Warn("warn信息................................");
       
            Console.ReadKey();

        }
    }
}

   运行程序,改程序会产生日志在\bin\Debug\或\bin\Release下面,并在控制台中也显示了日志

你可能感兴趣的:(sql,windows,SQL Server,sqlite,db2)