Log4j 配置 的webAppRootKey参数问题

为了让Web项目中的Spring 使用Log4j做如下配置:

1、在web.xml中添加如下内容:

<!--如果不定义webAppRootKey参数,那么webAppRootKey就是缺省的"webapp.root"。但最好设置,以免项目之间的名称冲突。

如我这里有两个项目都在web.xml都没配置webAppRootKey,那么这两个项目发布到tomcat时就会出现如下的异常:

Xml代码

  1. 严重: Exception sending context initialized event to listener instance of class org.springframework.web.util.Log4jConfigListener
  2. java.lang.IllegalStateException: Web app root system property already set to different value: ‘webapp.root‘ = [D:\apache-tomcat-6.0.29\webapps\UpLoadAndDownLoad\] instead of [D:\apache-tomcat-6.0.29\webapps\w\] - Choose unique values for the ‘webAppRootKey‘ context-param in your web.xml files!
  3. at org.springframework.web.util.WebUtils.setWebAppRootSystemProperty(WebUtils.java:146)
  4. at org.springframework.web.util.Log4jWebConfigurer.initLogging(Log4jWebConfigurer.java:118)
  5. at org.springframework.web.util.Log4jConfigListener.contextInitialized(Log4jConfigListener.java:47)
  6. at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4135)
  7. at org.apache.catalina.core.StandardContext.start(StandardContext.java:4630)
  8. at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791)
  9. at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771)
  10. at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:546)
  11. at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:1041)
  12. at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:964)
  13. at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:502)
  14. at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1277)
  15. at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:321)
  16. at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
  17. at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)
  18. at org.apache.catalina.core.StandardHost.start(StandardHost.java:785)
  19. at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
  20. at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:445)
  21. at org.apache.catalina.core.StandardService.start(StandardService.java:519)
  22. at org.apache.catalina.core.StandardServer.start(StandardServer.java:710)
  23. at org.apache.catalina.startup.Catalina.start(Catalina.java:581)
  24. at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  25. at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
  26. at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
  27. at java.lang.reflect.Method.invoke(Unknown Source)
  28. at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289)
  29. at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)
  30. 2010-10-10 17:18:18 org.apache.catalina.core.StandardContext start
  31. 严重: Error listenerStart

所以对多个项目要对webAppRootKey进行配置,这里主要是让log能将日志写到对应项目根目录下,如我配置这两个项目的webAppRootKey为

Xml代码

  1. <!-- 应用路径  -->
  2. <context-param>
  3. <param-name>webAppRootKey</param-name>
  4. <param-value>spring.webapp.root</param-value>
  5. </context-param>

Xml代码

  1. <!-- 应用路径  -->
  2. <context-param>
  3. <param-name>webAppRootKey</param-name>
  4. <param-value>spring.webapp.root2</param-value>
  5. </context-param>

这样就不会出现冲突了。

定义以后,在Web Container启动时将把ROOT的绝对路径写到系统变量里。
然后log4j的配置文件里就可以用${webName.root }来表示Web目录的绝对路径,把log文件存放于webapp中。

Xml代码  

  1. <!--此参数用于后面的“Log4jConfigListener”-->
  2. <context-param>
  3. <param-name>webAppRootKey</param-name>
  4. <param-value>webName.root</param-value>
  5. </context-param>
  6. <!--由Sprng载入的Log4j配置文件位置-->
  7. <context-param>
  8. <param-name>log4jConfigLocation</param-name>
  9. <param-value>/WEB-INF/log4j.properties</param-value>
  10. </context-param>
  11. <!--Spring默认刷新Log4j配置文件的间隔,单位为millisecond-->
  12. <context-param>
  13. <param-name>log4jRefreshInterval</param-name>
  14. <param-value>60000</param-value>
  15. </context-param>
  16. <!-- Web 项目 Spring 加载 Log4j 的监听 -->
  17. <listener>
  18. <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
  19. </listener>

2、编写log4j.properties属性文件,使用web.xml配置的全局变量:

log4j.appender.A_default.File=${webName.root}/WEB-INF/logs/log4j.log

详细内容略。

问题:
如上配置后,log4j.properties属性文件的存放位置,应在Web项目中的WEB-INF下,而不是默认的/WEB-INF/classes下。
可在做spring 的单元测试时,默认读取classes下的log4j.properties,不知该问题如何解决?

如果把log4j.properties存放在/WEB-INF/classes/log4j.properties下的话,会在启动Tomcat时报错:

log4j:ERROR setFile(null,true) call failed.
java.io.FileNotFoundException: \WEB-INF\logs\log4j.log (系统找不到指定的路径。)

可在\WEB-INF\logs\log4j.log 却可以看到log4j.log文件已存在Spring的日志输出信息。
分析可能是其他的类在加载log4j.properties时,无法读取${webName.root}变量的值。

时间: 2024-10-12 03:26:57

Log4j 配置 的webAppRootKey参数问题的相关文章

[转] Log4j 配置 的webAppRootKey参数问题

在tomcat下部署两个或多个项目时,web.xml文件中最好定义webAppRootKey参数,如果不定义,将会缺省为“webapp.root”,如下:<!-- 应用路径 --> <context-param> <param-name>webAppRootKey</param-name> <param-value>webapp.root</param-value> </context-param> 最好保持每个项目的参数

tomcat中部署多个项目,webAppRootKey 参数配置

在一个tomcat中部署多个项目时,需要在每个项目的web.xml中配置webAppRootKey参数,如下: <context-param> <param-name>webAppRootKey</param-name> <param-value>{your web app}.root</param-value> </context-param>

log4j配置参数详解——按日志文件大小、日期切分日志文件

项目中尽管对log4j有基本的配置,例如按天生成日志文件以作区分,但如果系统日志文件过大,则就需要考虑以更小的单位切分或者其他切分方式.下面就总结一下log4j常用的配置参数以及切分日志的不同方式. 一.基本配置解析 常用配置1: [java] view plain copy #日志级别,还可以log4j.rootLogger=INFO,file2,file3 指定file2.3的输出文件 log4j.rootLogger=info,exception,thread #info #每一天产生1个

Spring的Log4J配置器Log4jWebConfigurer介绍

1. Logj4简介 Log4j是Apache大旗下的一个子项目,它可以用来重定向应用日志文件的输出流,无论我们想将日志文件输出到控制台还是网络还是其他地方,都可以通过logj4来配置,如果我们的应用里面引入的Spring框架技术,我们可以通过Spring来初始化logj4的配置文件信息,下面2,3节是对Spring文档的一些翻译第4节是作者自己对一些问题的看法: 2. Log4jWebConfigurer及主要配置参数 Log4jWebConfigurer是一个方便的自定义log4j web环

log4j配置后行号乱码显示为?问号

debug="true"  classpathref="accrual.path" > 首发于 http://blog.xfuse.cn 参考文档 http://ant.apache.org/manual/CoreTasks/javac.html Log4j配置 log4j.appender.C1.layout.ConversionPattern=%F(%L)-- %-4r %-5p [%t] %37c %3x - %m%n 如果是用JAVAC编绎,那么直接加

spring集成Log4j以及log4j配置简要说明

Spring集成: web.xml中配置log4j <context-param> <param-name>log4jConfigLocation</param-name> <param-value>WEB-INF/log4j.xml</param-value></context-param> <!-- 加载Spring框架中的log4j监听器Log4jConfigListener --><listener>

Log4j配置详解

来自: http://www.blogjava.net/zJun/archive/2006/06/28/55511.html Log4J的配置文件(Configuration File)就是用来设置记录器的级别.存放器和布局的,它可接key=value格式的设置或xml格式的设置信息.通过配置,可以创建出Log4J的运行环境. 1. 配置文件 Log4J配置文件的基本格式如下: #配置根Loggerlog4j.rootLogger  =   [ level ]   ,  appenderName

#2014/7/24#常用log4j配置

常用log4j配置,一般可以采用两种方式,.properties和.xml,下面举两个简单的例子: 一.log4j.properties ### 设置org.zblog域对应的级别INFO,DEBUG,WARN,ERROR和输出地A1,A2 ## log4j.category.org.zblog=ERROR,A1 log4j.category.org.zblog=INFO,A2 log4j.appender.A1=org.apache.log4j.ConsoleAppender ### 设置输出

Log4j配置(转)

原文:http://www.blogjava.net/zJun/archive/2006/06/28/55511.html Log4J的配置文件(Configuration File)就是用来设置记录器的级别.存放器和布局的,它可接key=value格式的设置或xml格式的设置信息.通过配置,可以创建出Log4J的运行环境. 1. 配置文件Log4J配置文件的基本格式如下: #配置根Loggerlog4j.rootLogger  =   [ level ]   ,  appenderName1