Winform学习之随笔一:Log4net

前提题要:由于我最近负责的Winform项目,好多都用到了这个log4net的日志功能,开发程序对数据通常都要求作到雁过留痕,因此日志对于咱们程序员是不可或缺。所以我把对log4net的使用作一个记录总结,以便于之后的使用记忆。l程序员

1、概述数据库

       log4net是.Net下一个很是优秀的开源日志记录组件。 他是apache组织下面的一个工程,详见Apache介绍:https://baike.baidu.com/item/Apache软件基金会/2912769?fr=aladdin,   log4net记录日志的功能很是强大。它能够将日志分不一样的等级,以不一样的格式,输出到不一样的媒介。apache

2、一个小的案例实现过程缓存

    第一步、在项目中添加对log4net的引用,若是没有的话,能够手动在NuGet包里面寻找下载添加网络

    第二步、设置配置文件app

这个是个人winfrom里面的配置,供参考asp.net

 1  <configSections>
 2     <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
 3   </configSections>
 4   <startup useLegacyV2RuntimeActivationPolicy="true">
 5     <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.6.1" />
 6   </startup>
 7 
 8   <log4net>
 9     <root>
10       <level value="WARN" />
11       <appender-ref ref="LogFileAppender" />
12       <appender-ref ref="ConsoleAppender" />
13     </root>
14     <logger name="Logging">
15       <level value="DEBUG" />
16     </logger>
17     <appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
18       <file value="Logs/" />
19       <appendToFile value="true" />
20       <rollingStyle value="Date" />
21       <datePattern value="yyyy-MM-dd&quot;.log&quot;" />
22       <maxSizeToRollBackups value="-1" />
23       <maximumFileSize value="100MB" />
24       <staticLogFileName value="false" />
25       <layout type="log4net.Layout.PatternLayout,log4net">
26         <conversionPattern value="%d - %-5level - %c - %m%n" />
27       </layout>
28  
29       <filter type="log4net.Filter.LevelRangeFilter">
30         <param name="LevelMin" value="DEBUG" />
31         <param name="LevelMax" value="WARN" />
32       </filter>
33     </appender>
34     <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
35       <layout type="log4net.Layout.PatternLayout">
36         <param name="ConversionPattern" value="%d [%t] %-5p %c [%x] - %m%n" />
37       </layout>
38     </appender>
39   </log4net>
View Code

   第三步ide

若是是CS程序,在根目录的Program.cs中的Main方法中添加:spa

log4net.Config.XmlConfigurator.Configure();.net

若是是BS程序,在根目录的Global.asax.cs(没有新建一个)中的Application_Start方法中添加:

log4net.Config.XmlConfigurator.Configure();

不管BS仍是CS程序均可直接在项目的AssemblyInfo.cs文件里添加如下的语句:

[assembly: log4net.Config .XmlConfigurator()]

    第四步、声明一个日志容器

     

       我在配置文件中是这样设置的:

   第五步、在程序中使用

  

3、主要的组成部分

             1.Appenders

               Appenders用来定义日志的输出方式,即日志要写到那种介质上去。较经常使用的Log4net已经实现好了,直接在配置文件中调用便可,可参见上面配置文件例子;固然也能够本身写一个,须要从       log4net.Appender.AppenderSkeleton类继承。它还能够经过配置Filters和Layout来实现日志的过滤和输出格式。

              已经实现的输出方式有:

AdoNetAppender 将日志记录到数据库中。能够采用SQL和存储过程两种方式。

AnsiColorTerminalAppender 将日志高亮输出到ANSI终端。

AspNetTraceAppender  能用asp.net中Trace的方式查看记录的日志。

BufferingForwardingAppender 在输出到子Appenders以前先缓存日志事件。

ConsoleAppender 将日志输出到应用程序控制台。

EventLogAppender 将日志写到Windows Event Log。

FileAppender 将日志输出到文件。

ForwardingAppender 发送日志事件到子Appenders。

LocalSyslogAppender 将日志写到local syslog service (仅用于UNIX环境下)。

MemoryAppender 将日志存到内存缓冲区。

NetSendAppender 将日志输出到Windows Messenger service.这些日志信息将在用户终端的对话框中显示。

OutputDebugStringAppender 将日志输出到Debuger,若是程序没有Debuger,就输出到系统Debuger。若是系统Debuger也不可用,将忽略消息。

RemoteSyslogAppender 经过UDP网络协议将日志写到Remote syslog service。

RemotingAppender 经过.NET Remoting将日志写到远程接收端。

 RollingFileAppender 将日志以回滚文件的形式写到文件中。

SmtpAppender 将日志写到邮件中。

SmtpPickupDirAppender 将消息以文件的方式放入一个目录中,像IIS SMTP agent这样的SMTP代理就能够阅读或发送它们。

TelnetAppender 客户端经过Telnet来接受日志事件。

TraceAppender 将日志写到.NET trace 系统。

UdpAppender 将日志以无链接UDP数据报的形式送到远程宿主或用UdpClient的形式广播。

     2.Filters

使用过滤器能够过滤掉Appender输出的内容。过滤器一般有如下几种:

DenyAllFilter 阻止全部的日志事件被记录

LevelMatchFilter 只有指定等级的日志事件才被记录

LevelRangeFilter 日志等级在指定范围内的事件才被记录

LoggerMatchFilter 与Logger名称匹配,才记录

PropertyFilter 消息匹配指定的属性值时才被记录

StringMathFilter 消息匹配指定的字符串才被记录

3.Layouts

Layout用于控制Appender的输出格式,能够是线性的也能够是XML。

一个Appender只能有一个Layout。

最经常使用的Layout应该是经典格式的PatternLayout,其次是SimpleLayout,RawTimeStampLayout和ExceptionLayout。而后还有IRawLayout,XMLLayout等几个,使用较少。Layout能够本身实现,须要从log4net.Layout.LayoutSkeleton类继承,来输出一些特殊须要的格式,在后面扩展时就从新实现了一个Layout。

SimpleLayout简单输出格式,只输出日志级别与消息内容。

RawTimeStampLayout 用来格式化时间,在向数据库输出时会用到。

样式如“yyyy-MM-dd HH:mm:ss“

ExceptionLayout须要给Logger的方法传入Exception对象做为参数才起做用,不然就什么也不输出。输出的时候会包含Message和Trace。

PatterLayout使用最多的一个Layout,能输出的信息不少。

4.Loggers

Logger是直接和应用程序交互的组件。Logger只是产生日志,而后由它引用的Appender记录到指定的媒介,并由Layout控制输出格式。

Logger提供了多种方式来记录一个日志消息,也能够有多个Logger同时存在。每一个实例化的Logger对象对被log4net做为命名实体(Named Entity)来维护。log4net使用继承体系,也就是说假如存在两个Logger,名字分别为a.b.c和a.b。那么a.b就是a.b.c的祖先。每一个Logger都继承了它祖先的属性。全部的Logger都从Root继承,Root自己也是一个Logger。

日志的等级,它们由高到底分别为:

OFF > FATAL > ERROR > WARN > INFO > DEBUG  > ALL 

高于等级设定值方法(如何设置参见“配置文件详解”)都能写入日志, Off全部的写入方法都不写到日志里,ALL则相反。例如当咱们设成Info时,logger.Debug就会被忽略而不写入文件,可是FATAL,ERROR,WARN,INFO会被写入,由于他们等级高于INFO。

在具体写日志时,通常能够这样理解日志等级:

FATAL(致命错误):记录系统中出现的能使用系统彻底失去功能,服务中止,系统崩溃等使系统没法继续运行下去的错误。例如,数据库没法链接,系统出现死循环。

ERROR(通常错误):记录系统中出现的致使系统不稳定,部分功能出现混乱或部分功能失效一类的错误。例如,数据字段为空,数据操做不可完成,操做出现异常等。

WARN(警告):记录系统中不影响系统继续运行,但不符合系统运行正常条件,有可能引发系统错误的信息。例如,记录内容为空,数据内容不正确等。

INFO(通常信息):记录系统运行中应该让用户知道的基本信息。例如,服务开始运行,功能已经开户等。

DEBUG (调试信息):记录系统用于调试的一切信息,内容或者是一些关键数据内容的输出。

Logger实现的ILog接口,ILog定义了5个方法(Debug,Inof,Warn,Error,Fatal)分别对不一样的日志等级记录日志。这5个方法还有5个重载。以Debug为例说明一下,其它的和它差很少。

ILog中对Debug方法的定义以下:

void Debug(object message);

void Debug(object message, Exception ex);

还有一个布尔属性:

bool IsDebugEnabled { get; }

若是使用Debug(object message, Exception ex),则不管Layout中是否认义了%exception,默认配置下日志都会输出Exception。包括Exception的Message和Trace。若是使用Debug(object message),则日志是不会输出Exception。

最后还要说一个LogManager类,它用来管理全部的Logger。它的GetLogger静态方法,能够得到配置文件中相应的Logger:

log4net.ILog log = log4net.LogManager.GetLogger("logger-name");

5.Object Renders

它将告诉logger如何把一个对象转化为一个字符串记录到日志里。(ILog中定义的接口接收的参数是Object,而不是String。)

例如你想把Orange对象记录到日志中,但此时logger只会调用Orange默认的ToString方法而已。因此要定义一个OrangeRender类实现log4net.ObjectRender.IObjectRender接口,而后注册它(咱们在本文中的扩展不使用这种方法,而是直接实现一个自定义的Layout)。这时logger就会知道如何把Orange记录到日志中了。

       6.Repository

         Repository主要用于日志对象组织结构的维护。  

 PS来源:https://blog.csdn.net/binnygoal/article/details/79557746

相关文章
相关标签/搜索