1、Log4net介绍数据库
log4net是一个功能著名的开源日志记录组件。利用log4net能够方便地将日志信息记录到文件、控制台、Windows事件日志和数据库(包括MS Server,Access,Oracle9i,Oracle8i,DB2,SQLite)中。而且咱们还能够记载控制要记载的日志级别,能够记载的日志类别包括:FATAL(致命错误)、ERROR(通常错误)、WARN(警告)、INFO(通常信息)、DEBUG(调试信息)。最新下载地址:http://logging.apache.org/log4net/apache
2、log4net的结构缓存
log4net有四种主要的组件,分别是Logger(记录器),Repository(库),Appender(附着器),Layout(布局);网络
2.1 Logger框架
Logger是应用程序交互的主要组件,它用来产生日志消息。产生的日志消息并不直接显示,还要预先通过Layout的格式化处理后才会输出。asp.net
2.2 Repositoryless
Repository主要用于负责日志对象组织结构的维护。在log4net的之前版本中,框架仅支持分等级的组织结构(hierarchical organization)。这种等级结构本质上是库的一个实现,而且定义在log4net.Repository.Hierarchy 名字空间中。要实现一个Repository,须要实现log4net.Repository.ILoggerRepository 接口。可是一般并非直接实现该接口,而是以log4net.Repository.LoggerRepositorySkeleton为基类继承。体系库 (hierarchical repository )则由log4net.Repository.Hierarchy.Hierarchy类实现。布局
若是你是个log4net框架的使用者,而非扩展者,那么你几乎不会在你的代码里用到Repository的类。相反的,你须要用到LogManager类来自动管理库和日志对象。.net
2.3 Appender调试
一个好的日志框架应该可以产生多目的地的输出。好比说输出到控制台或保存到一个日志文件。log4net 可以很好的知足这些要求。它使用一个叫作Appender的组件来定义输出介质。正如名字所示,这些组件把它们附加到Logger日志组件上并将输出传递到输出流中。你能够把多个Appender组件附加到一个日志对象上。 Log4net框架提供了几个Appender组件。关于log4net提供的Appender组件的完整列表能够在log4net框架的帮助手册中找到。有了这些现成的Appender组件,通常来讲你没有必要再本身编写了。可是若是你愿意,能够从log4net.Appender.AppenderSkeleton类继承。
2.4 Appender Filter
一个Appender 对象缺省地将全部的日志事件传递到输出流。Appender的过滤器(Appender Filters) 能够按照不一样的标准过滤日志事件。在log4net.Filter的名字空间下已经有几个预约义的过滤器。使用这些过滤器,你能够按照日志级别范围过滤日志事件,或者按照某个特殊的字符串进行过滤。你能够在API的帮助文件中发现更多关于过滤器的信息。
2.5 Layout
Layout 组件用于向用户显示最后通过格式化的输出信息。输出信息能够以多种格式显示,主要依赖于咱们采用的Layout组件类型。能够是线性的或一个XML文件。Layout组件和一个Appender组件一块儿工做。API帮助手册中有关于不一样Layout组件的列表。一个Appender对象,只能对应一个Layout对象。要实现你本身的Layout类,你须要从log4net.Layout.LayoutSkeleton类继承,它实现了ILayout接口。