.NET开源项目介绍及资源推荐:日志记录

在项目开发中,日志记录是任什么时候候都少不了的,在本文中,将简单介绍一下以下几种日志记录工具,以及推荐一些学习的资源:
1 Log4net
2 Logging Application Block
3 NLog
 
一.Log4net
Log4net 是从java平台下很是优秀的日志记录框架log4j上移植到.NET下的,它是apache基金资助的项目的一部分。Log4net能够帮助咱们把日志信息输出到各类不一样目标(文本文件、数据库、控制台等)的.net类库,它能够容易的加载到开发项目中,实现程序调试和运行的时候的日志信息输出,提供了比.net本身提供的debug类和trace类的功能更多,使用起来也是很是的简单。在Log4net 主要有四种重要的组件,分别是Logge, Repository, Appender以及 LayoutLog4net支持两种不一样的配置方式:配置文件和代码配置,通常状况下推荐使用配置文件,一个完整的配置示例以下:
<? xml version="1.0" encoding="utf-8"  ?>
< configuration >
  
< configSections >
    
< section  name ="log4net"  
      type
="log4net.Config.Log4NetConfigurationSectionHandler, 
            log4net-net-1.0"
  />
  
</ configSections >

  
< log4net >

    
< root >
      
< level  value ="WARN"   />
      
< appender-ref  ref ="AdoNetAppender"   />
      
< appender-ref  ref ="ConsoleAppender"   />
    
</ root >

    
< logger  name ="testApp.Logging" >
      
< level  value ="DEBUG" />
    
</ logger >

    
< appender  name ="AdoNetAppender"  type ="log4net.Appender.AdoNetAppender" >
      
< bufferSize  value ="100"   />
      
< connectionType  value ="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"   />
      
< connectionString  value ="data source=[database server];initial catalog=[database name];integrated security=false;persist security info=True;User ID=[user];Password=[password]"   />
      
< commandText  value ="INSERT INTO Log ([Date],[Thread],[Level],[Logger],[Message],[Exception]) VALUES (@log_date, @thread, @log_level, @logger, @message, @exception)"   />
      
< parameter >
        
< parameterName  value ="@log_date"   />
        
< dbType  value ="DateTime"   />
        
< layout  type ="log4net.Layout.RawTimeStampLayout"   />
      
</ parameter >
      
< parameter >
        
< parameterName  value ="@thread"   />
        
< dbType  value ="String"   />
        
< size  value ="255"   />
        
< layout  type ="log4net.Layout.PatternLayout" >
          
< conversionPattern  value ="%thread"   />
        
</ layout >
      
</ parameter >
      
< parameter >
        
< parameterName  value ="@log_level"   />
        
< dbType  value ="String"   />
        
< size  value ="50"   />
        
< layout  type ="log4net.Layout.PatternLayout" >
          
< conversionPattern  value ="%level"   />
        
</ layout >
      
</ parameter >
      
< parameter >
        
< parameterName  value ="@logger"   />
        
< dbType  value ="String"   />
        
< size  value ="255"   />
        
< layout  type ="log4net.Layout.PatternLayout" >
          
< conversionPattern  value ="%logger"   />
        
</ layout >
      
</ parameter >
      
< parameter >
        
< parameterName  value ="@message"   />
        
< dbType  value ="String"   />
        
< size  value ="4000"   />
        
< layout  type ="log4net.Layout.PatternLayout" >
          
< conversionPattern  value ="%message"   />
        
</ layout >
      
</ parameter >
      
< parameter >
        
< parameterName  value ="@exception"   />
        
< dbType  value ="String"   />
        
< size  value ="2000"   />
        
< layout  type ="log4net.Layout.ExceptionLayout"   />
      
</ parameter >
    
</ appender >

    
< appender  name ="ConsoleAppender"  
              type
="log4net.Appender.ConsoleAppender"   >
      
< layout  type ="log4net.Layout.PatternLayout" >
        
< param  name ="ConversionPattern"  
           value
="%d [%t] %-5p %c [%x] - %m%n"  
        
/>
      
</ layout >
    
</ appender >

  
</ log4net >
</ configuration >
在该示例中,配置了两种目标的输出,分别为数据库和控制台方式,在代码中使用示例:
Log4net.ILog log  =  Log4net.LogManager.GetLogger( " MyLogger " ); 

if  (log.IsDebugEnabled)
    log.Debug(
" message " ); 

if  (log.IsInfoEnabled)
   log.Info(
" message " );
Log4net 已经可以彻底知足咱们平常开发的日志记录功能,可是它容易为人所诟病的一点是没有可视化的配置工具支持,须要手工编写配置文件。若是你还在担忧这一点,不妨看看这篇《Log4net GUI configuration tool》文章,文中做者为咱们提供了一种Log4net的可视化配置工具,界面以下所示:
学习资料
1 Log4net官方文档
2 Sema翻译的Log4net使用指南 (我的认为,若是你从没有接触过Log4net,看这篇就足够使用它了)
3 .菩提树的Log4net五步走也很值得推荐。
 
二.Logging Application Block
Logging Application Block 是微软Enterprise Library其中的一个应用程序块,可使开发人员能够在其应用程序中集成标准的日志和监测功能,应用程序可使用日志和监测块在多个位置记录事件,记录的位置包括:事件日志(Event Log)、电子邮件(Email)、数据库(DataBase)、文本文件(TextFile)、消息队列(MSMQ)、WMI、用户自定义位置。而且使用Enterprise Library Configuration工具进行彻底可视化配置,而且能够设置输出日志信息的格式。如图所示:
配置完成后,全部的配置都放在了应用程序配置文件里面(针对EL2.0):
< configuration >
  
< configSections >
    
< section  name ="loggingConfiguration"  type ="Microsoft.Practices.EnterpriseLibrary.Logging.Configuration.LoggingSettings, Microsoft.Practices.EnterpriseLibrary.Logging"   />
  
</ configSections >
  
< loggingConfiguration  tracingEnabled ="true"  defaultCategory ="General" >
    
< logFilters >
      
< add
          
name ="Category"
          type
="Microsoft.Practices.EnterpriseLibrary.Logging.Filters.CategoryFilter, Microsoft.Practices.EnterpriseLibrary.Logging"
          categoryFilterMode
="AllowAllExceptDenied" >
        
< categoryFilters >
          
< add  name ="UI Events"   />
        
</ categoryFilters >
      
</ add >
      
< add
          
name ="Priority"
          type
="Microsoft.Practices.EnterpriseLibrary.Logging.Filters.PriorityFilter, Microsoft.Practices.EnterpriseLibrary.Logging"
          minimumPriority
="2"
                    
/>
      
< add  name ="LogEnabled Filter"
        type
="Microsoft.Practices.EnterpriseLibrary.Logging.Filters.LogEnabledFilter, Microsoft.Practices.EnterpriseLibrary.Logging, Version=2.0.0.0, Culture=neutral, PublicKeyToken=null"
        enabled
="true"  
           
/>
    
</ logFilters >
  
</ loggingConfiguration >
</ configuration >
在代码中使用时很是简单,以下代码片段所示:
LogEntry logEntry  =   new  LogEntry();

logEntry.EventId 
=   100 ;

logEntry.Priority 
=   2 ;

logEntry.Message 
=   " Informational message " ;

// 设置多个Category

logEntry.Categories.Add(
" Trace " );

logEntry.Categories.Add(
" UI Events " );


Logger.Write(logEntry);
不少朋友使用 Logging Application Block,有一个担忧的地方就是 Enterprise Library 2.0中把全部的配置信息都放在了应用程序配置文件里面,这样由配置工具生成的配置代码和咱们手工添加的一些配置代码混合在一块儿,会显得很是混乱,若是你有这样的疑问,想把每个应用程序块的配置信息单独放在外部文件中,不妨看看这篇文章《 Enterprise Library 2.0 技巧(1):如何使用外部配置文件
关于Logging Application Block还应该提一下它的可扩展性,除了系统中默认的输出目标以外,用户能够自行扩展本身的目标,好比说控制台等;除此以外,用户也能够扩展本身的日志输出格式,好比说XML格式等。
学习资源
 
三.NLog
NLog C#编写的开源日志类库,它的设计思想是使其简单而灵活。NLog让你处理诊断的日志消息,用相关信息扩充消息,依照你的选择格式化日志消息和把日志消息输出到一个或多个目的地,基本上相似于Log4net。一样,NLog也提供了不少的扩展,能够自定义日志输出目标,日志格式,过滤器等。看一个简单的配置示例:
< nlog  xmlns ="http://www.nlog-project.org/schemas/NLog.xsd"  
      xmlns:xsi
="http://www.w3.org/2001/XMLSchema-instance" >
  
< targets >
    
< target  name ="console"  xsi:type ="ColoredConsole"  
            layout
="${date:format=HH\:mm\:ss}|${level}|${stacktrace}|${message}" />
    
< target  name ="file"  xsi:type ="File"  fileName ="${basedir}/file.txt"  
            layout
="${stacktrace} ${message}" />
  
</ targets >
  
< rules >
    
< logger  name ="*"  minlevel ="Trace"  writeTo ="console,file" />
  
</ rules >
</ nlog >
在代码中使用以下所示:
static   void  C() 

    logger.Info(
"Info CCC"); 
}
 

static   void  B() 

    logger.Trace(
"Trace BBB"); 
    logger.Debug(
"Debug BBB"); 
    logger.Info(
"Info BBB"); 

    C(); 

    logger.Warn(
"Warn BBB"); 
    logger.Error(
"Error BBB"); 
    logger.Fatal(
"Fatal BBB"); 
}
 

static   void  A() 

    logger.Trace(
"Trace AAA"); 
    logger.Debug(
"Debug AAA"); 
    logger.Info(
"Info AAA"); 

    B(); 

    logger.Warn(
"Warn AAA"); 
    logger.Error(
"Error AAA"); 
    logger.Fatal(
"Fatal AAA"); 
}
 

static   void  Main( string [] args) 

    logger.Trace(
"This is a Trace message"); 
    logger.Debug(
"This is a Debug message"); 
    logger.Info(
"This is an Info message"); 

    A(); 

    logger.Warn(
"This is a Warn message"); 
    logger.Error(
"This is an Error message"); 
    logger.Fatal(
"This is a Fatal error message"); 

}
NLog 虽然没有提供可视化的配置工具,可是安装后,咱们会在VS2005New Item里面看到有关本NLog的配置文件这么一项,是用该配置文件是支持自动补全功能的。
学习资源
没有发现目前有好的中文学习资源,你们能够参考官方文档,但愿有时间能够写几篇NLog的使用教程,弥补一下当前中文文档的空缺。
 
总结
以上简单的介绍了.NET下的几种开源日志记录框架,若是你的系统总体架构都使用了Enterprise Library,那么使用Logging Application Block更适合你;不然,若是使用了NHiberante或者Castle等数据持久框架,那么选用Log4net将会更适合,由于在NH中自己就是用Log4net做为日志记录工具的;在没有使用任何其余框架的状况下,能够在以上几种工具中自行选用,我的认为它们都很优秀!