在tomcat下面同时启动多个项目的时候出现了一个错误,刚开始没找见,后来在网上查看才知道是自己对log4j配置不清楚造成的。
使用spring中的Log4jConfigListener有如如下好处:
1. 动态的改变记录级别和策略,不需要重启Web应用,如《Effective Enterprise Java》所说。
2. 把log文件定在 /WEB-INF/logs/ 而不需要写绝对路径。
因为 系统把web目录的路径压入一个叫webapp.root的系统变量。这样写log文件路径时不用写绝对路径了.
log4j.appender.logfile.File=${webapp.root}/WEB-INF/logs/myfuse.log
3. 可以把log4j.properties和其他properties一起放在/WEB-INF/ ,而不是Class-Path。
1、 web.xml配置
<context-param>
<param-name>webAppRootKey</param-name>
<param-value>webapp.root</param-value>
</context-param>
"webapp.root"这个字符串可以随便写任何字符串。如果不配置默认值是"webapp.root"。
例如 我现在第一个项目设置的是webapp.root 运行的时候就会出现这个
信息: Initializing log4j from [F:\Workspaces\MyEclipseProfessional\.metadata\.me_tcat7\webapps\weshop\WEB-INF\classes\log4j.properties]
这个。
由于我的两个项目的context-param设置的param-value都是webapp.root那么当启动的时候就会报错,因为你的webapp.root的这个key的value值已经制定了第一个项目,不能再指向第二个项目,所以就会报错。把第二个项目的param-value改掉,项目启动无错误。
最后再说下这个
<context-param>
<param-name>webAppRootKey</param-name>
<param-value>tsts.root</param-value>
</context-param>
<span style="color: rgb(60, 60, 60); font-family: Arial, sans-serif; font-size: 14px; line-height: 21px;">然后再配置这样一个监听器:</span><pre name="code" class="html"><listener>
<listener-class>
org.springframework.web.util.WebAppRootListener
</listener-class>
</listener>
<p style="color: rgb(60, 60, 60); font-family: Arial, sans-serif; font-size: 14px; line-height: 21px;">这个监听器就会在web上下文初始化的时候,调用webUtil的对应方法,首先获取到param-name对应的param-value ,然后,根据传递进去的ServletContext对象得到web的物理路径:String root = servletContext.getRealPath("/");</p><p style="color: rgb(60, 60, 60); font-family: Arial, sans-serif; font-size: 14px; line-height: 21px;">接着把这个param-value作为key,root作为value放到system中System.setProperty(key, root);然后再web中可以用 System.get.....就可以得到web的跟目录的物理路径了。</p>终于明白了