一、Log4j有三个主要的组件:Loggers,Appenders和Layouts,这里可简单理解为日志级别,日志要输出的地方和日志格式
1、 Logger
Logger的日志级别有6级,分别是TRACE<DEBUG < INFO < WARN < ERROR < FATAL 分别按照一定的等级来表示此条日志的重要程度
2、 appender常用的输出有控制台、文件、数据库等
二、Log4j2配置
1、web.xml配置文件
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
<listener>
<listener-class>org.apache.logging.log4j.web.Log4jServletContextListener</listener-class> </listener> <filter> <filter-name>log4jServletFilter</filter-name> <filter-class>org.apache.logging.log4j.web.Log4jServletFilter</filter-class> </filter> <filter-mapping> <filter-name>log4jServletFilter</filter-name> <url-pattern>/*</url-pattern> <dispatcher>REQUEST</dispatcher> <dispatcher>FORWARD</dispatcher> <dispatcher>INCLUDE</dispatcher> <dispatcher>ERROR</dispatcher> </filter-mapping> |
2、log4j2的配置文件:log4j2.xml ,建在类路径下
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 |
<?xml version="1.0" encoding="utf-8"?>
<Configuration status="off" monitorInterval="1800"> <properties> <property name="filename">d:/logs/log4j.log</property> </properties> <Appenders> <!--输出到控制台配置--> <Console name="Console"> <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss } %p %l %m%n" /> </Console> <!--输出到文件配置--> <RollingFile name="file" fileName="${filename}" filePattern="d:/logs/log4j--%d{yyyy-MM-dd}.log.gz"> <PatternLayout pattern="%d{HH:mm:ss.SSS} %p %C:%L %m%n" /> <TimeBasedTriggeringPolicy interval="1" modulate="“true”" /> </RollingFile> </Appenders> <Loggers> <!--com.render包下的日志输出策略,输出warn级别及以上级别的日志到控制台和文件--> <Logger name="com.render" level="warn" additivity="false"> <AppenderRef ref=" Console" /> <AppenderRef ref="file" /> </Logger> <!--其它日志输出策略--> <Root level="error"> <AppenderRef ref="file" /> <AppenderRef ref="Console" /> </Root> </Loggers> </Configuration> |
上述配置可以将日志打印到控制台的同时,保存到文件 除此之外,log4j2的JDBC Appender还支持将日志输出到数据库保存 首先,需要配置一个JNDI数据源,具体配置方式可参见:
[Tomcat下配置Jndi数据源](http://blog.csdn.net/kris234seth/article/details/46694971)
之后在上述log4j2的配置文件中新增Jdbc Appender之后的配置:
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 |
<?xml version="1.0" encoding="utf-8"?>
<Configuration status="off" monitorInterval="1800"> <properties> <property name="filename">d:/logs/log4j.log</property> </properties> <Appenders> <!--输出到控制台配置--> <Console name="Console"> <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss } %p %l %m%n" /> </Console> <!--输出到文件配置--> <RollingFile name="file" fileName="${filename}" filePattern="d:/logs/log4j--%d{yyyy-MM-dd}.log.gz"> <PatternLayout pattern="%d{HH:mm:ss.SSS} %p %C:%L %m%n" /> <TimeBasedTriggeringPolicy interval="1" modulate="“true”" /> </RollingFile> <!--JdbcAppender配置--> <JDBC name="JdbcAppender" tableName="logger"> <DataSource jndiName="java:/comp/env/jndi" /> <!--日期时间配置--> <Column name="eventDate" isEventTimestamp="true" /> <!--日志输出级别--> <Column name="level" pattern="%level" /> <!--日志对应的类--> <Column name="Class" pattern="%C:%L" /> <!--日志对应的方法--> <Column name="Method" pattern="%M" /> <!--日志内容--> <Column name="message" pattern="%message" /> <!--本次操作请求的ip地址--> <Column name="ip" pattern="%X{ip}" /> <!--本次操作请求的用户id--> <Column name="userid" pattern="%X{userid}" /> </JDBC> </Appenders> <Loggers> <!--com.render包下的日志输出策略,输出warn级别及以上级别的日志到控制台和文件--> <Logger name="com.render" level="warn" additivity="false"> <AppenderRef ref=" Console" /> <AppenderRef ref="file" /> </Logger> <!--其它日志输出策略--> <Root level="error"> <AppenderRef ref="file" /> <AppenderRef ref="Console" /> </Root> </Loggers> </Configuration> |
说明:logger为保存日志的表名,jndiName为容器中配置的JNDI数据源的名称,column元素中的name属性为表的字段名
注意:上述配置中的最后2项,即用户id和ip地址(可以使其它任何信息)是需要单独来进行处理,才能在数据库保存成功,这时需要借助org.apache.log4j.MDC这个类来对id和ip进行设置。MDC是一个保存特定context数据的map,类似于session对象。具体使用方式如下:
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 + “的用户请求”); |
注意:一定要在在日志打印语句之前进行id和ip信息(同样可以是其它任何需要的信息)的设置!
这样设置之后,在配置文件中就可以使用%X{ip}、%X{userid}来取到对应的值。
除此之外,对于要保存的一些公共的信息,每次在打印日志的时候都需要使用MDC来进行设置,这对于代码的书写时很繁琐的,解决这个问题,我们可以把这些信息的设置放置到一个过滤器中,在请求开始的时候就进行相关信息的设置,这样就不需要每次都单独设置了。
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 "); } } } |
<filter>
< filter-name > AuthFilter < /filter-name >
< filter-class > com.log4jmdc.AuthenticationFilter </filter-class >
</filter >
< filter-mapping >
< filter-name > AuthFilter </filter-name>
< url-pattern >/*</url-pattern>
</filter-mapping>
以上所有的配置都完成了,启动项目可以进行测试,看看日志有没有存到数据库吧!