log4j2使用总结

一、Log4j有三个主要的组件:Loggers,Appenders和Layouts,这里可简单理解为日志级别,日志要输出的地方和日志格式

1、 Logger

Logger的日志级别有6级,分别是TRACE

2、 appender常用的输出有控制台、文件、数据库等

二、Log4j2配置

1、web.xml配置文件

 XML Code 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16

  org.apache.logging.log4j.web.Log4jServletContextListener


  log4jServletFilter
  org.apache.logging.log4j.web.Log4jServletFilter


  log4jServletFilter
  /*
  REQUEST
  FORWARD
  INCLUDE
  ERROR


2、log4j2的配置文件:log4j2.xml ,建在类路径下

 XML Code 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
= "1.0"  encoding= "utf-8" ?>
= "off"  monitorInterval= "1800" >
  
     = "filename" >d: /logs /log4j.log
  
  
    
     = "Console" >
       = "%d{yyyy-MM-dd HH:mm:ss } %p %l %m%n"  />
    
    
     = "file"  fileName= "${filename}"  filePattern= "d:/logs/log4j--%d{yyyy-MM-dd}.log.gz" >
       = "%d{HH:mm:ss.SSS} %p %C:%L %m%n"  />
       = "1"  modulate= "“true”"  />
    
  
  
    
     = "com.render"  level= "warn"  additivity= "false" >
       = " Console"  />
       = "file"  />
    
    
     = "error" >
       = "file"  />
       = "Console"  />
    
  

上述配置可以将日志打印到控制台的同时,保存到文件 除此之外,log4j2的JDBC Appender还支持将日志输出到数据库保存 首先,需要配置一个JNDI数据源,具体配置方式可参见: 

[Tomcat下配置Jndi数据源](http://blog.csdn.net/kris234seth/article/details/46694971) 

之后在上述log4j2的配置文件中新增Jdbc Appender之后的配置: 

 XML Code 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
="1.0" encoding="utf-8"?>
="off" monitorInterval="1800">
  
    ="filename">d:/logs/log4j.log
  
  
    
    ="Console">
      ="%d{yyyy-MM-dd HH:mm:ss } %p %l %m%n" />
    
    
    ="file" fileName="${filename}" filePattern="d:/logs/log4j--%d{yyyy-MM-dd}.log.gz">
      ="%d{HH:mm:ss.SSS} %p %C:%L %m%n" />
      ="1" modulate="“true”" />
    
    
    ="JdbcAppender" tableName="logger">
      ="java:/comp/env/jndi" />
      
      ="eventDate" isEventTimestamp="true" />
      
      ="level" pattern="%level" />
      
      ="Class" pattern="%C:%L" />
      
      ="Method" pattern="%M" />
      
      ="message" pattern="%message" />
      
      ="ip" pattern="%X{ip}" />
      
      ="userid" pattern="%X{userid}" />
    
  
  
    
    ="com.render" level="warn" additivity="false">
      =" Console" />
      ="file" />
    
    
    ="error">
      ="file" />
      ="Console" />
    
  

说明:logger为保存日志的表名,jndiName为容器中配置的JNDI数据源的名称,column元素中的name属性为表的字段名

注意:上述配置中的最后2项,即用户idip地址(可以使其它任何信息)是需要单独来进行处理,才能在数据库保存成功,这时需要借助org.apache.log4j.MDC这个类来对idip进行设置。MDC是一个保存特定context数据的map,类似于session对象。具体使用方式如下:

 Java Code 
1
2
3
4
5
6
String userid =  25;
String ip = ”  127. 0. 0.0”;
MDC.put(“userid”, userid);
MDC.put(“ip”, ip);
logger.info(“来自ip地址为:” +ip + “, id为” +userid + “的用户请求”);

注意:一定要在在日志打印语句之前进行idip信息(同样可以是其它任何需要的信息)的设置!

这样设置之后,在配置文件中就可以使用%X{ip}、%X{userid}来取到对应的值。
除此之外,对于要保存的一些公共的信息,每次在打印日志的时候都需要使用MDC来进行设置,这对于代码的书写时很繁琐的,解决这个问题,我们可以把这些信息的设置放置到一个过滤器中,在请求开始的时候就进行相关信息的设置,这样就不需要每次都单独设置了。

 Java Code 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
public  class AuthenticationFilter  implements Filter
{

    @Override
     public  void doFilter(ServletRequest request, ServletResponse response,
                         FilterChain chain)  throws IOException, ServletException
    {
        HttpServletRequest re = (HttpServletRequest) request
         //这里可以从request中获取到session中的用户相关信息、ip地址、请求的uri等等信息
         try
        {

            MDC.put( "userid"16);

            chain.doFilter(request, response);

        }
         finally
        {
            MDC.remove( "userid ");
        }

    }

}
增加了过滤器之后还需要在web.xml文件中增加过滤器的相关配置,如下


< filter-name > AuthFilter < /filter-name >
< filter-class > com.log4jmdc.AuthenticationFilter

< filter-mapping >
< filter-name > AuthFilter
< url-pattern >/*

以上所有的配置都完成了,启动项目可以进行测试,看看日志有没有存到数据库吧!




你可能感兴趣的:(JavaEE)