为了让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
严重: Exception sending context initialized event to listener instance of class org.springframework.web.util.Log4jConfigListener
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!at org.springframework.web.util.WebUtils.setWebAppRootSystemProperty(WebUtils.java:146)at org.springframework.web.util.Log4jWebConfigurer.initLogging(Log4jWebConfigurer.java:118)at org.springframework.web.util.Log4jConfigListener.contextInitialized(Log4jConfigListener.java:47)at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4135)at org.apache.catalina.core.StandardContext.start(StandardContext.java:4630)at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791)at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771)at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:546)at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:1041)at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:964)at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:502)at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1277)at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:321)at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)at org.apache.catalina.core.StandardHost.start(StandardHost.java:785)at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:445)at org.apache.catalina.core.StandardService.start(StandardService.java:519)at org.apache.catalina.core.StandardServer.start(StandardServer.java:710)at org.apache.catalina.startup.Catalina.start(Catalina.java:581)at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)at java.lang.reflect.Method.invoke(Unknown Source)at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289)at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)
2010-10-10 17:18:18 org.apache.catalina.core.StandardContext start
严重: 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>
<!-- 应用路径  --><context-param><param-name>webAppRootKey</param-name><param-value>spring.webapp.root</param-value></context-param>
Xml代码  
  1. <!-- 应用路径  -->
  2. <context-param>
  3. <param-name>webAppRootKey</param-name>
  4. <param-value>spring.webapp.root2</param-value>
  5. </context-param>
<!-- 应用路径  --><context-param><param-name>webAppRootKey</param-name><param-value>spring.webapp.root2</param-value></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>
<!--此参数用于后面的“Log4jConfigListener”-->
<context-param>
<param-name>webAppRootKey</param-name>
<param-value>webName.root</param-value>
</context-param><!--由Sprng载入的Log4j配置文件位置-->
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>/WEB-INF/log4j.properties</param-value>
</context-param><!--Spring默认刷新Log4j配置文件的间隔,单位为millisecond-->
<context-param>
<param-name>log4jRefreshInterval</param-name>
<param-value>60000</param-value>
</context-param><!-- Web 项目 Spring 加载 Log4j 的监听 -->
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</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}变量的值。

转自:http://nopainnogain.iteye.com/blog/780542

转载于:https://www.cnblogs.com/webcc/archive/2012/05/29/2523522.html

Log4j 配置的webAppRootKey参数问题相关推荐

  1. java log4j 配置_Java:log4j与log4j.properties的配置说明

    [来源:Java |作者:Java |时间:2007-7-20 |去论坛]--在强调可重用组件开发的今天,除了自己从头到尾开发一个可重用的日志操作类外,Apache为我们提供了一个强有力的日志操作包- ...

  2. stone 的 log4j配置详解

    stone 的 log4j配置详解 Log4J的配置文件(Configuration File)就是用来设置记录器的级别.存放器和布局的,它可接key=value格式的设置或xml格式的设置信息.通过 ...

  3. Log4j配置学习文档之一 log4j配置

    #Log4j配置 Log4J的配置文件(Configuration File)就是用来设置记录器的级别.存放器和布局的,它可接key=value格式的设置或xml格式的设置信息.通过配置,可以创建出L ...

  4. hibernate log4j配置祥解

    log4j配置祥解 第一步:加入log4j-1.2.8.jar到lib下. 第二步:在CLASSPATH下建立log4j.properties.内容如下: 1 log4j.rootLogger=INF ...

  5. Log4J配置方式Java工程测试

    2019独角兽企业重金招聘Python工程师标准>>> Log4J配置方式 1.  导入jar包 Commons-logging .jar Log4j-1.2.17.jar 2.  ...

  6. Python中sklearn中HistGradientBoostingRegressor回归器配置单调约束参数monotonic_cst提高回归模型的抗噪声以及局部扰动的能力

    Python中sklearn中HistGradientBoostingRegressor回归器配置单调约束参数monotonic_cst提高回归模型的抗噪声以及局部扰动的能力 目录

  7. log4j 配置,tomcat 启动或有后台操作时,控制台会显示很多 DEBUG 信息

    log4j 配置,tomcat 启动或有后台操作时,控制台会显示很多 DEBUG 信息 日志信息可以以文件形式显示,也可以在控制台输出,在 log4j.properties 文件设置. 控制台有很多 ...

  8. log4j配置目标到mongodb

    首先,具体采用什么技术作为集中式存储方案在99%的应用中应该来说并没有多大区别,最重要的是要定期清理不必要的日志,以及日志格式设计(也可以重写org.log4mongo.MongoDbPatternL ...

  9. log4j配置日志系统成功 (转)

    .引言: <log4j相比System.out的优势>(自己blog中的文章)     Log4j就是帮助开发人员进行日志输出管理的API类库.它最重要的特点就可以配置文件灵活的设置日 志 ...

最新文章

  1. c语言测序,一次Hi-C建库测序,两种分析,你不心动?
  2. 强化学习之三:双臂赌博机(Two-armed Bandit)
  3. 9.1 图像处理的基本概念(图像读入、图像信息查询、图像显示和图像存储)
  4. 逻辑回归Logistic Regression 之基础知识准备
  5. linux rm 不释放_linux删除文件空间不释放问题解决
  6. SpringBoot与MyBatis技术集成
  7. 安卓 App 库存系统开发 终端设备 SDK 分析
  8. SQL--报错回显注入
  9. 为什么SSD目标检测算法对小目标检测的效果不好
  10. element UI指定下拉框样式修改
  11. 修改Eclipse配色方案
  12. 笔试必备:48道SQL练习题(Oracle为主)
  13. 小王的智能箱子,看完泪目
  14. LTDC-DMA2D显示屏显示-编码标准(三)
  15. 详解DBSCAN聚类
  16. 2022 七校联合NewStarCTF 公开赛赛道 WEEK2|CRYPTO
  17. 基于OpenCV的形状检测
  18. Linux目录与管理
  19. Python时间包datetime的使用
  20. ashx aspx asmx

热门文章

  1. 设置时间同步(ntp)详细步骤
  2. 微调︱caffe中fine-tuning模型三重天(函数详解、框架简述)+微调技巧
  3. @babel/polyfill按需加载
  4. Linux基础命令---ftp
  5. 5分钟搭一个FastDFS--Linux篇
  6. STM32.SPI(25Q16)
  7. 初识webservice 服务
  8. Mysql笔记——DCL
  9. RFID将成为物联网革命的首战
  10. Twproject Gantt – 开源的 JavaScript 甘特图组件