web应用的log4j配置

完全不懂,大致看了一会儿,发现一些信息:

  1. web应用的log4j使用基本上都采用:新建一个servlet,这个servlet在init函数中为log4j执行配置。一般就是读入配置文件。所以需要在web.xml中为这个servlet配置,同时设定load-on-startup为1。
  2.  这个servlet配置log4j就是读出配置文件,然后调用configure函数。这里有两个问题:一、需要知道文件在哪里;二、需要正确的文件类型
  3. 配置文件位置在web.xml中配置一个param即可,路径一般是相对于web的root目录
  4. 文件类型一般有两种,一个是Java的property文件,另一种是xml文件
  5. 配置文件的大致内容:log4j可以指定输出的log级别的最低等级,以及log的输出配置格式,每个log可以指定多个输出方式
     <logger name="org.woden" additivity="false">  
      <level value="DEBUG" />  
      <appender-ref ref="console.log" />  
      <appender-ref ref="file.log " />  
     </logger>  
    其中的appender就是一个log输出,这里引用了两个log位置。
  6. appender的格式大概如下:
    <appender name="file.log" class="org.apache.log4j.RollingFileAppender">  
    <!-- 这里必须用绝对路径(或相对于tomcat的路径) -->  
      <param name="File" value="c:\logs\myweb.log" />  
      <param name="Append" value="false" />  
      <layout class="org.apache.log4j.PatternLayout">  
    <param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss} [%C:%M()]-[%p] %m%n" />  
    恩,在class属性中可以定义一个log4j给的类,可以指定输出的方式。这里是RollingFileAppender。表示往文件添加log,然后达到max之后新建一个文件。
  7. 其实log4j和spring已经给我们提供了一个更加方便的方法:利用他们已经提供给我们的servlet类,og4j的com.apache.jakarta.log4j.Log4jInit类,Spring的org.springframework.web.util.Log4jConfigServlet和 org.springframework.web.util.ServletContextListene。不过还不清楚具体怎么搞

部分代码来自于:http://qify.iteye.com/blog/340930

补充一个:这个网站的例子非常详细了http://www.avajava.com/tutorials/lessons/how-do-i-initialize-log4j-in-a-web-application.html


你可能感兴趣的:(spring,tomcat,log4j,Web,servlet,Class)