ASP.NET中使用Apache log4net

分类: asp.net技巧   出处:iocblog整理  更新时间:2008-06-22   添加到收藏  

log4net是apache log4j的.net版,是一套xml配置型的日志引擎,正好最近有个程序需要日志系统,为了整合方便,就决定研究一下。感谢郝伟推荐。

 log4net系统划分了7个日志等级,如设置为"warn",则debug,info不会被记录。如下:

1. all

2. debug

3. info

4. warn

5. error

6. fatal

7. off

creating the sample application

 

step 1: 下载log4net

去logging.apache.org/log4net,来获取他们的最近版,在例子里我用的是incubating-log4net-1.2.9-beta.zip,期待正式版。

 

step 2: 创建 asp.net web 应用程序

    创建这个就不多说了,在log4net-1.2.0-beta8in et如图。找到对应的dll,添加到引用里。有的版本没有编译好的dll,那就自己编一下吧,用.net v1.0的那个版本转换成1.1或2.0的。我觉得这不是工作失误,是故意的。他们玩java玩惯了的人好多都是这样。

configuring the sample application

 

step 3: 添加assembly信息

打开assemblyinfo.cs文件,添加:

[assembly: log4net.config.domconfigurator()]
这句话的意思是log4net系统会自动寻找配置文件web.config从而获得并加载其中的配置信息。如果想log4net随时监视配置文件以便重新加载的话就
稍微麻烦点了要这样写:


[assembly:log4net.config.domconfigurator(configfile="filename",configfileextension="log4net",watch=true)]

step 4: 添加配置信息

要编辑web.config文件了,真是每次看见它都有惊喜啊。找到configuration标签,configsections要紧挨着写到它下面(一点都不替别人考虑,要在有一个也跟他一样霸道怎么办?那就单写个它的日志配置文件吧!我估计apache他们就是这么想的)。看看例子吧:


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

<configuration>

 <configsections>

    <section name="log4net"

             type="log4net.config.log4netconfigurationsectionhandler, log4net-net-1.0"

    />[来源www.iocblog.net]

 </configsections>

 

 <!-- this section contains the log4net configuration settings -->

 <log4net>

    <!-- define some output appenders -->

    <appender name="consoleappender" type="log4net.appender.consoleappender">

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

        <param name="conversionpattern" value="%d [%t] %-5p %c [%x] &lt;%x{auth}&gt; - %m%n" />

      </layout>

    </appender>

    <!-- rollingfileappender looks after rolling over files by size or date -->

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

      <param name="file" value="c:\log\rollingloghelloworld.log" />

      <param name="appendtofile" value="true" />

      <param name="maxsizerollbackups" value="10" />

      <param name="maximumfilesize" value="1000" />

      <param name="rollingstyle" value="size" />

      <param name="staticlogfilename" value="true" />

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

        <param name="conversionpattern" value="%d [%t] %-5p %-45c [%x] - %m%n" />

      </layout>

    </appender>

    <!-- fileappender appends to a log and it is manually managed or size -->

    <appender name="fileappender" type="log4net.appender.fileappender">

      <param name="file" value="loghelloworld.log" />     

      <!-- example using environment variables in params -->

      <!-- <param name="file" value="${tmp}\applicationkit.log" /> -->

      <param name="appendtofile" value="true" />

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

        <param name="conversionpattern" value="%d [%t] %-5p %c [%x] - %m%n" />

      </layout>

    </appender>

    <!-- setup the root category, add the appenders and set the default level -->

    <root>

      <level value="info" />

      <appender-ref ref="consoleappender" />

    </root>

    <!-- applicationkit category - the presentation ui -->

    <logger name="webform1">

      <level value="info" />

      <appender-ref ref="fileappender" />

    </logger>

 </log4net>

</configuration>

 

注意logger节点的name属性设的是webform1,这里指的是类名。要给每一个需要添加log的类都添加一个这样的节点。想起了osworkflow工作流了,灵活与方便实用往往不可兼得。这里的级别是info,也就是说,info以下的不会被记录。

running the sample application

 

step 5: 添加一个 log 类

首先是添加引用

using log4net;using log4net.config; //然后是实例化如果认真研究了配置文件,那么这个声明方式就很好理解了:private static readonly ilog log = logmanager.getlogger("webform1");

 
step 6: 使用 log对象

到了现在,所有的配置工作都已经完成了,接下来的工作就是测试一下,把他和应用层连起来。随便加一个按钮在响应事件button1_click event handler.中添加

[来源www.iocblog.net]
log.info("hello world, i am a logger");


step 7: run the application

现在可以运行了,应该是个这样子的:

这样每次点击按钮,在日至文件中就会出现

2006-02-13 10:12:30,671 [1228] info webform1 [] - hello world, i am a logger这样一条记录。


总结:

简单易用,过一阵再研究sql日志吧,db才素王道,呵呵。

更多信息参见http://logging.apache.org/log4net/

 


Tag: log4net