Spring集成Log4j和Slf4j

[toc]

Log4j的集成

Spring项目中集成Log4j

  1. 下载好log4j的jar包(例如:log4j-1.2.11.jar)
  2. web.xml
<!--log4j配置文件加载-->  
<context-param>      
   <param-name>log4jConfigLocation</param-name>      
   <param-value>/WEB-INF/log4j.properties</param-value>      
</context-param>  
<!--启动一个watchdog线程每1800秒扫描一下log4j配置文件的变化--> 
<!-- log4j 配置扫描刷新间隔 可以不用 --> 
<context-param>      
   <param-name>log4jRefreshInterval</param-name>      
   <param-value>1800000</param-value>      
</context-param>   

<!--spring log4j监听器-->  
<listener>      
   <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>      
</listener> 

只配置listener也可以

  1. log4j.properties
    日志的主配置文件
log4j.rootLogger=info,stdout,debug,error    
log4j.logger.org.springframework=info
#log4j.logger.org.springframework.web=debug
log4j.appender.stdout=org.apache.log4j.ConsoleAppender    
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout    
log4j.appender.stdout.layout.ConversionPattern=[%-5p] [%d{HH\:mm\:ss}] %c - %m%n    

log4j.logger.info=info    
log4j.appender.info=org.apache.log4j.DailyRollingFileAppender    
log4j.appender.info.layout=org.apache.log4j.PatternLayout    
log4j.appender.info.layout.ConversionPattern=[%-5p] [%d{HH\:mm\:ss}] %c - %m%n    
log4j.appender.info.datePattern='.'yyyy-MM-dd    
log4j.appender.info.Threshold = INFO    
log4j.appender.info.append=true    
log4j.appender.info.File=${catalina.home}/logs/log4j/info.log
log4j.appender.warn.File=${catalina.home}/logs/log4j/warn.log    

log4j.logger.debug=debug    
log4j.appender.debug=org.apache.log4j.DailyRollingFileAppender    
log4j.appender.debug.layout=org.apache.log4j.PatternLayout    
log4j.appender.debug.layout.ConversionPattern=[%-5p] [%d{HH\:mm\:ss}] %c - %m%n    
log4j.appender.debug.datePattern='.'yyyy-MM-dd    
log4j.appender.debug.Threshold = DEBUG    
log4j.appender.debug.append=true    
log4j.appender.debug.File=${catalina.home}/logs/log4j/debug.log

log4j.logger.warn=warn    
log4j.appender.warn=org.apache.log4j.DailyRollingFileAppender    
log4j.appender.warn.layout=org.apache.log4j.PatternLayout    
log4j.appender.warn.layout.ConversionPattern=[%-5p] [%d{HH\:mm\:ss}] %c - %m%n    
log4j.appender.warn.datePattern='.'yyyy-MM-dd    
log4j.appender.warn.Threshold = DEBUG    
log4j.appender.warn.append=true    

log4j.logger.error=error    
log4j.appender.error=org.apache.log4j.DailyRollingFileAppender    
log4j.appender.error.layout=org.apache.log4j.PatternLayout    
log4j.appender.error.layout.ConversionPattern=[%-5p] [%d{HH\:mm\:ss}] %c - %m%n    
log4j.appender.error.datePattern='.'yyyy-MM-dd    
log4j.appender.error.Threshold = ERROR    
log4j.appender.error.append=true    
log4j.appender.error.File=${catalina.home}/logs/log4j/error.log
  1. 代码中写入日
private static final Logger logger = LoggerFactory.getLogger(XXX.class);
logger.info("XXXX");
logger.warn("XXXX");
logger.error("XXXX");

Slf4j的集成

Slf4j不是一个真正的日志实现,而是一个抽象层,它允许我们在后台使用任意一个日志类库。所以以后更换为其它日志工具时,只要修改配置文件,不用修改代码,所以开源框架常用到Slf4j。
spring 4默认是不依赖slf4j的,只依赖common logging.
集成好Log4j之后就可直接使用Slf4j了

  1. 加入slf4j的jar包
  2. 配置同上Log4j的配置

即集成好Log4j之后就可直接使用Slf4j了。
使用:

import org.slf4j.Logger;  
import org.slf4j.LoggerFactory;
...
private static final Logger logger = LoggerFactory.getLogger(User.class);  
文章目录
  1. 1. Log4j的集成
  2. 2. Slf4j的集成