`
yzxqml
  • 浏览: 134870 次
  • 性别: Icon_minigender_1
  • 来自: 广西
文章分类
社区版块
存档分类
最新评论

Web app root system property already set to different value 错误原因及解决

阅读更多

 

Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件、甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。最令人感兴趣的就是,这些可以通过一个配置文件来灵活地进行配置,而不需要修改应用的代码。

 

其实呢,我觉得他就是一个能对我们的WEB应用监控的组件,让我们可以了解到我们的程序运行的情况 ,以及出错后的相关记录。

 

 我在用的时候报了一个错误

严重: 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:\MyEclipseProject\.metadata\.me_tcat\webapps\ReservationSystem\] instead of [D:\MyEclipseProject\.metadata\.me_tcat\webapps\SpringMVCDemo\] - Choose unique values for the 'webAppRootKey' context-param in your web.xml files!

 

我们来看一下Log4j的配置:

log4j.rootLogger=INFO, stdout, logfile

log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.HTMLLayout
#log4j.appender.stdout.layout.ConversionPattern=%d %p [%c] - %m%n
log4j.appender.stdout.layout.ConversionPattern=- %m%n

log4j.appender.logfile=org.apache.log4j.RollingFileAppender 
log4j.appender.logfile.File=${webapp.root}/webapp.html
log4j.appender.logfile.MaxFileSize=512KB


# Keep three backup files.
log4j.appender.logfile.MaxBackupIndex=3
# Pattern to output: date priority [category] - message
log4j.appender.logfile.layout=org.apache.log4j.HTMLLayout
log4j.appender.logfile.layout.ConversionPattern=%d %p [%c] - %m%n

log4j.logger.com.opensymphony.xwork2=ERROR 

# Control logging for other open source packages
log4j.logger.org.springframework=ERROR
log4j.logger.org.quartz=ERROR
log4j.logger.net.sf.ehcache=ERROR
log4j.logger.net.sf.navigator=ERROR
log4j.logger.org.apache.commons=ERROR
log4j.logger.org.apache.struts=ERROR
log4j.logger.org.hibernate=DEBUG 
# Struts OgnlUtil issues unimportant warnings 
log4j.logger.com.opensymphony.xwork2.util.OgnlUtil=error 
log4j.logger.com.opensymphony.xwork2.ognl.OgnlValueStack=error

 发现没有什么问题啊,但是,请注意${webapp.root}这个变量 ,对照着错误提示大概看了一下,意思是说Web应用程序根系统属性已经被设置,说白了就是说'webapp.root' 这个配置名称已经被使用了,不能再用这个了,

并且也提示了Choose unique values for the 'webAppRootKey' context-param in your web.xml files ,也就是说我们可以在web.xml里配置一个唯一的'webAppRootKey' ,这样就不会冲突了。

 

这个问题会出现在一个WEB服务器同时部署多个使用了Log4j的应用上,如果配置不当,出这个错误还真会让你郁闷到抓狂。我就是出这个问题了,一个Tomcat部署了2个使用了Log4j的项目。

 

然后我这样解决:按给的提示在web.xml里加上

<context-param>
    <param-name>webAppRootKey</param-name>
    <param-value>myapp.root</param-value>
</context-param>

 然后在 log4j.properties里就写成${myapp.root},只要这个名称不重复,就不会产生Web app root system property already set to different value的错误了。虽然正式使用时一台服务器部署多个应用程序的情况会比较少,但是还是保险起见吧,也对我们的程序相关的命名标准化吧,把

 ${webapp.root}改成${[应用程序].root},这是个好习惯。

 

 

分享到:
评论
2 楼 nod22 2016-02-29  
这个问题还真是隐蔽 如果你不知道看localhost.log文件 还真不知道哪的原因 我再一个tomcat上部署了2个项目,就是不能同时启动。原来两个都没有指定 appkey 所以第二个项目log4就报错了
1 楼 zqb666kkk 2013-05-13  
很好 解决了我的一个问题

相关推荐

    tomcat部署多个项目.pdf

    `java.lang.IllegalStateException: Web app root system property already set to dif` 这个异常是因为多个项目中的 `web.xml` 文件中没有配置 `webAppRootKey` 项,导致 Tomcat 无法正确地分配项目的根目录。 ...

    读取webroot文件下的属性文件

    首先,确保属性文件已经放置在webroot目录下,例如:`/webroot/config/app.properties`。这个文件应包含键值对,如`key=value`的格式。 步骤1:导入所需库 在Java代码中,我们需要使用`java.util.Properties`类来...

    Office Web App Server 2013

    Add-WindowsFeature Web-Server,Web-WebServer,Web-Common-Http,Web-Static-Content,Web-App-Dev,Web-Asp-Net,Web-Net-Ext,Web-ISAPI-Ext,Web-ISAPI-Filter,Web-Includes,Web-Security,Web-Windows-Auth,Web-...

    appweb4.3.4-0添加arm配置及源代码

    2. **主循环**:在`src/appweb.c`中,你可以找到服务器的主要事件循环,这是AppWeb运行的核心部分。 3. **配置解析**:AppWeb使用`conf.c`和`conf.h`中的函数来解析配置文件。了解这些函数的工作原理,可以方便地...

    appweb 8.2.1

    总之,AppWeb 8.2.1 提供了一个强大且灵活的嵌入式 Web 服务器解决方案,尤其适合需要高效、安全 Web 服务的嵌入式和 IoT 应用场景。通过深入理解和熟练使用,开发者可以充分利用其功能,打造高性能的网络服务。

    Embedded Appweb移植 安装 应用

    Embedded Appweb 移植 安装 应用是指将 Appweb 服务器移植到嵌入式系统中,安装并配置 Appweb 服务器,以实现 Web 服务。Appweb 服务器是一个小巧、灵活、可扩展的 Web 服务器,支持多种功能特性,包括 Full ...

    appweb+esp.zip

    编译问题及解决方案: 在将AppWeb和ESP整合到Hi3559平台时,可能会遇到诸如依赖库缺失、编译选项不兼容、硬件驱动不匹配等问题。首先,确保所有必要的编译工具链和库已安装,如GCC交叉编译器、OpenSSL等。其次,调整...

    利用app_process实现免root调用shell_Java_下载.zip

    然而,通过巧妙地利用`app_process`,可以实现在不获取root权限的情况下调用shell命令,这对于一些需要进行系统级交互的应用场景非常有用。下面我们将详细探讨如何利用`app_process`来实现这一目标,以及在Java中...

    SystemProperty-Setting-APP:APK,用于设置系统属性

    SystemProperty-Setting-APP Environment: Android Studio / Android 5.0 Description: This app is the system app, which need to be build in android framework or be signed. And this app is the example ...

    appweb嵌入式WebServer服务器学习笔记

    ### appweb嵌入式WebServer服务器学习笔记 #### 一、概述 本文档主要介绍了如何构建一个基于HTML和JavaScript的简单嵌入式WebServer服务器,特别聚焦于使用Appweb框架来实现这一目标。通过本篇笔记,我们将了解...

    Web-to-App技术解决方案,驱动变现增效-1017北京站.zip

    Web-to-App技术是当前移动互联网领域中一种重要的策略,旨在将网页应用(Web App)与原生应用程序(Native App)的优势相结合,为用户提供无缝的跨平台体验,同时提高商业变现效率。在这个主题中,我们将深入探讨Web...

    一键冰箱免ROOT指令.zip_ROOT_冰箱app免root_冰箱一件免root_冰箱一键_安装冰箱免root

    综合以上信息,这个压缩包提供了一个解决方案,让用户能够在不获取ROOT权限的情况下,利用ADB工具启动和使用冰箱App。对于那些不想或者不能ROOT手机但又希望使用冰箱功能的用户来说,这是一个非常实用的工具。用户只...

    android 把软件安装成系统软件(安装到system/app目录下)

    首先,确保你的设备已经root,因为system/app目录通常只可由root用户访问和修改。同时,你可能需要使用如BusyBox这样的工具,因为它提供了许多Linux命令行工具,对于执行本操作至关重要。 #### 步骤二:备份与确认 ...

    将应用部署到weblogic10及oracle linux遇到的问题及解决方案

    在部署应用时,遇到了 java.lang.IllegalStateException: Cannot set web app root system property when WAR file is not expanded 问题。出现这个原因是因为部署的时候使用的是 WAR 包,WebLogic 部署应用不像 ...

    Android应用程序请求root权限代码

    - **如何检测设备是否已被root**:可以通过检查某些root标志文件(如`/system/app/Superuser.apk`)是否存在来判断设备是否已获取root权限。 - **root权限的风险**:虽然root权限可以带来更多的自由度和功能,但同时...

    Android修改源码让APP获取root权限可以执行su命令的git diff记录

    修改源码让APP获取root权限可以执行su命令的git diff记录

    Android9.0 开放root权限

    主要是针对P版开发adb root和app root权限,资源基于MTK方案。

    android系统自带system/app

    在Android操作系统中,"system/app"是一个至关重要的目录,它包含了Android系统预装的应用程序。这些应用程序是系统的核心组成部分,通常由设备制造商或Google预先安装,以提供基本功能和服务。让我们深入探讨一下这...

    solaredge-web-set-app:适用于SolarEdge Web-set-app的Protobuf定义

    solaredge-web-set-app背景支持SolarEdge SetApp的逆变器具有用于调试的集成Web服务器,该服务器还提供状态信息。 该前端主要包含在JavaScript程序中。 如果运行以下命令,将会看到您拥有哪个版本JavaScript程序: ...

Global site tag (gtag.js) - Google Analytics