`
fishergay
  • 浏览: 33103 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

spring log4j 集成的那些事

 
阅读更多

1.使用spring集成log4j可以动态指定log日志输出到web项目路径中, 不用写死路径, 还可以动态修改log4j配置文件的日志级别。

2.在集成的过程中,记录一下我遇到的问题

 

log4j.property 配置文件

 

log4j.rootLogger=DEBUG,CONSOLE,FILE

log4j.logger.com.lysoft=DEBUG

#apche log
log4j.logger.org.apache.commons=ERROR

#spring log
#log4j.logger.org.springframework=DEBUG
log4j.logger.org.springframework.transaction=DEBUG

#hibernate log
log4j.logger.org.hibernate=DEBUG
log4j.logger.org.hibernate.SQL=DEBUG
log4j.logger.org.hibernate.hql=DEBUG
log4j.logger.org.hibernate.jdbc=DEBUG
log4j.logger.net.sf.ehcache=DEBUG 
log4j.logger.org.hibernate.cache=DEBUG
log4j.logger.org.hibernate.transaction=DEBUG
log4j.logger.org.hibernate.tool.hbm2ddl=DEBUG
log4j.logger.org.hibernate.hql.internal.ast=ERROR

#valuelist log
log4j.logger.net.mlw.vlh=ERROR

#c3p0 log
log4j.logger.com.mchange.v2.resourcepool.BasicResourcePool=DEBUG

#out log to console
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%p] [%t] [%c:%L] - %m%n

# Pattern to output the caller's file name and line number.
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%-4r %-5p [%d{yyyy-MM-dd HH:mm:ss}]  %m%n

#out log to file
log4j.appender.FILE=org.apache.log4j.RollingFileAppender
log4j.appender.FILE.File=${ssh.root}/WEB-INF/logs/error.log
log4j.appender.FILE.MaxFileSize=5120KB
log4j.appender.FILE.MaxBackupIndex=10
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.ConversionPattern=[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%p] [%t] [%c:%L] - %m%n



 

我把log4j配置文件放在classpath中的,和spring集成后在,我的项目名称叫SSH,会在SSH/WEB-INF/logs/error.log  路径下面生成一个error.log日志文件, 由于我的tomcat是在d盘,还会在d:/WEB-INF/logs/error.log生成一个文件, 看着非常不爽, 如果部署到客户机器上面,2个地方生成日志,日志大的话,非常占空间,觉得还不爽,打算追根到底看是怎么回事, 于是上网查了下集成的文章, 对比下没有什么区别,就log4j配置文件放在WEB-INF下面,不过这样修改后启动tomcat会有warn

 

log4j:WARN No appenders could be found for logger (org.springframework.web.context.ContextLoader).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.

 

网上也没有说怎么解决,而且做单元测试的时候也会找不到log4j的配置文件。

后来找到一篇文章说要把Log4jConfigListener 配置放在ContextLoaderListener配置的前面, 这样说来, 看看上面的warn也就知道怎么回事了, 也弄明白了我之前为什么会生成2个log日志文件了,如果是放在classpath下面,ContextLoaderListener可以自动找到log4j配置文件的路径,会根据log4j配置文件中log4j.appender.logfile.File=${ssh.root}/WEB-INF/logs/error.log这个配置在我d盘d:/WEB-INF/logs/error.log生成一个日志文件,由于Log4jConfigListener 还没有初始化,所以${ssh.root}这个取值是空的,就剩下WEB-INF/logs/error.log了,tomcat放在d盘,就形成了d:/WEB-INF/logs/error.log 

最后修正还是把log4j配置文件放在classpath下面(src目录),  修改web.xml配置

 

 

<!-- 加载log4j配置 -->
  	<!-- 注意一定要放在org.springframework.web.context.ContextLoaderListener之前 -->
  	<context-param>
		<param-name>webAppRootKey</param-name>
	  	<param-value>ssh.root</param-value>
	</context-param>
	<context-param> 
	   <param-name>log4jConfigLocation</param-name> 
	   <param-value>classpath:log4j.properties</param-value> 
	</context-param> 
	<!-- log4j每隔60秒扫描 一下配置文件的变化 -->
	<context-param> 
	   <param-name>log4jRefreshInterval</param-name> 
	   <param-value>60000</param-value> 
	</context-param>
	<listener>
		<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
	</listener>
  	
  	<!-- 初始化spring context -->
  	<context-param>
	  	<param-name>contextConfigLocation</param-name>
	  	<param-value>classpath:applicationContext-*.xml</param-value>
	</context-param>
	<listener>
		<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
	</listener>

 

修改后 不再生成2个日志文件了,单元测试日志显示也正常了, 动态修改log4j配置文件日志级别也能用了。

 

 

 

2
3
分享到:
评论
4 楼 yiqi1943 2015-04-11  
谢谢分享,解决了问题
3 楼 superxielei 2013-05-10  
angelhau 写道
放到web目录下面,是不太明智的。会对对项目的更新制造一些麻烦。
其实想要指定目录可以用${catalina.home}/logs/这种。catalina.home是全局变量,就是你的tomcat的跟路径。

同意~
2 楼 fishergay 2013-04-15  
好的, 谢谢, 回头试试。。
1 楼 angelhau 2013-04-15  
放到web目录下面,是不太明智的。会对对项目的更新制造一些麻烦。
其实想要指定目录可以用${catalina.home}/logs/这种。catalina.home是全局变量,就是你的tomcat的跟路径。

相关推荐

Global site tag (gtag.js) - Google Analytics