天天看点

如何使用log4net

第一步,工程中引入log4net.dll

第二步,在assemblyinfo.cs加入这一行,指定log4net的配置文件

[assembly: log4net.config.xmlconfigurator(configfile="cxylog4net.exe.config", watch=true)]

 第三步,在配置文件中指定以下内容

<?xml version="1.0" encoding="utf-8" ?>

<configuration>

    <configsections>

        <section name="log4net" type="log4net.config.log4netconfigurationsectionhandler, log4net" />

    </configsections>

    <log4net debug="true">

        <appender name="rollinglogfileappender" type="log4net.appender.rollingfileappender">

            <file value="e: est.log" />

            <appendtofile value="true" />

            <rollingstyle value="size" />

            <maxsizerollbackups value="10" />

            <maximumfilesize value="2kb" />

            <staticlogfilename value="true" />

            <layout type="log4net.layout.patternlayout">

                <footer value="[footer]--test by cxy1981 
" />

                <conversionpattern value="%-5p %d %5rms %-22.22c{1} %-18.18m - %m%n" />

            </layout>

        </appender>

        <root>

            <priority value="all" />

            <appender-ref ref="rollinglogfileappender" />

        </root>

    </log4net>

</configuration>

第五步,在类中写下以下内容

using log4net;

private static readonly ilog log = logmanager.getlogger(

  system.reflection.methodbase.getcurrentmethod().declaringtype);

这样我们就可使用log4net来记录我们所需要的内容了

if (log.iserrorenabled)

{

    log.error("page load failed : " + ex.message);

}

以下是转自这个地址的关于log4net的说明

<a href="http://www.cnblogs.com/liwei6797/archive/2007/04/27/729679.html">http://www.cnblogs.com/liwei6797/archive/2007/04/27/729679.html</a>

log4net核心组成

log4net主要由五个部分组成,分别为logger,appenders, filters, layouts 和object renders。

一)logger(日志)

1.记录日志的分类:

log4net能够以多种方式输出日志。支持的日志输出常用的主要媒介有数据库(包括ms sql server, access, oracle9i,oracle8i,db2,sqlite,控制台,文件,事件日志(可以用事件查看器查看)和邮件等多种方式。

2. 日志的级别

log4net支持多种级别的日志。优先级从高到低依次排列如下:

fatal &gt; error &gt; warn &gt; info &gt; debug

此外还有all(允许所有的日志请求)和off(拒绝所有的日志请求)这两种特殊的级别。

二)appenders

appenders决定日志输出的方式。

appenders必须实现log4net.appenders.iappender接口。

log4net目前支持的输出方式包括:

1 adonetappender

    将日志记录到数据库中。可以采用sql和存储过程两种方式。

2 ansicolorterminalappender

    在ansi 窗口终端写下高亮度的日志事件。

3 aspnettraceappender

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

4 bufferingforwardingappender

    在输出到子appenders之前先缓存日志事件。

5 consoleappender

    将日志输出到控制台。

6 eventlogappender

    将日志写到windows event log.

7 fileappender

    将日志写到文件中。

8 localsyslogappender

    将日志写到local syslog service (仅用于unix环境下).

9 memoryappender

    将日志存到内存缓冲区。

10 netsendappender

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

11 remotesyslogappender

    通过udp网络协议将日志写到remote syslog service。

12 remotingappender

    通过.net remoting将日志写到远程接收端。

13 rollingfileappender

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

14 smtpappender

    将日志写到邮件中。

15 traceappender

    将日志写到.net trace 系统。

16 udpappender

    将日志connectionless udp datagrams的形式送到远程宿主或以udpclient的形式广播。

三)filters

appender对象将日志以缺省的方式传到输出流,然后filter可以按照不同的标准控制日志的输出。filter可以再配置文件中配置。最简单的形式是在appender中写明一个threshold.这样只有级别大于或等于此threshold的日志才被记录。

filters必须实现log4net.filters.ifilter接口。

四)layouts

layouts控制日志显示的格式样式。日志的显示格式如下:

"%timestamp [%thread] %-5level %logger - %message%newline"

timestamp: 表示程序已经开始执行的时间。 单位[毫秒]。

thread:执行当前代码的线程。

level:日志的级别。

logger:日志相关请求的名称。

message: 日志消息。

layouts还可以控制日志的输出样式,比如以普通形式或以xml等形式输出。

五) object renderers

这是很重要的一项,log4net将按照用户定义的标准输出日志消息。

object renders必须实现log4net.objectrenderer.iobjectrenerer接口。

小例子的源代码

http://dl2.csdn.net/down4/20070713/13172335911.rar