接着上一篇Blog,现在开始整理Tomcat服务器方面的报错及其处理步骤.
在Eclispe里启动Tomcat,此时报如下一个异常:
log4j:ERROR Could not parse file [E:\myMMT\.metadata\.plugins\org.eclipse.wst.server.core\tmp0/conf/log4j.xml].
java.io.FileNotFoundException: E:\myMMT\.metadata\.plugins\org.eclipse.wst.server.core\tmp0\conf\log4j.xml (系统找不到指定的文件。)
异常里所说的路径就是E:\myMMT是我Eclipse新建的WorkSpace,这里的conf文件夹是它下面的.metadata里对Tomcat所做的插件支持(这个我推测的,现在看来这个推测没什么问题).
为什么要去这个conf下找log4j.xml呢?这当然是Tomcat要去找与Logging相关的配置了,可一个全新Tomcat下又没有log4j.xml这个文件,那么在Tomcat里又是怎么来配置Logging的呢?这个先不考虑,在此据以往经验把那个log4j.xml文件从Link进来的conf文件中拷到Eclipse中Servers下与项目A相对应的Tomcat的config下,这里面现在已有原来的catalina.policy,catalina.properites,server.xm.,tomcat-user.xml四个文件.放入再重启Tomcat后,上面的那个异常还存在,这是怎么回事?通过右击config文件Easy Explore后,看到这个文件的路径是这样的:E:\myMMT\Servers\Tomcat v5.5 Server at localhost-config. 现在回过头来想想,为什么我要把那个log4j.xml文件放到Tomcat v5.5 Server at localhost-config这个文件夹下呢?异常中报的是在tmp0\conf下找不到,又没说是在Tomcat v5.5 Server at localhost-config下找不到?是想看看Eclipse会不会自动地找这个log4j.xml文件拷到那个tem0下,现在得出结论了:不能自动copy过去.
这里留一个问题,那个E:\myMMT\Servers\Tomcat v5.5 Server at localhost-config文件与E:\myMMT\.metadata\.plugins\org.eclipse.wst.server.core\tmp0\conf文件夹有什么联系?难道会涉及到CATALINA-BASE这个概念么?先不想这个.
那现在自己乖乖地把log4j.xml放到E:\myMMT\.metadata\.plugins\org.eclipse.wst.server.core\tmp0\conf下吧.
重启Tomcat后,那个异常没了.不过现在有个问题:与log4j.xml同在一个conf文件夹下另外还有A.properties,A.xml,A-cachemapping.properties,A-echache.xml和system.properties五个文件.据现在的现象看来Tomcat在启动时没有找这个四个文件.这四个文件会在什么情况下用到呢?
现在Tomcat启动了,在浏览器中访问,看看还会有什么异常.
怪怪...怎么浏览器里访问里所404异常呢?
虚惊一场,原来是Project的名字写错了,应该是abc的,可写成acb了.这样为好,看看这样的project名字冲突会带来什么影响.
进去登录界面输入用户名密码后,点击Login button.又有异常了.现在是"applicationContext.xml"这个文件找不到.这是怎么回事呢?那个文件明明在这个"E:\myMMT\.metadata\.plugins\org.eclipse.wst.server.core\tmp0\wtpwebapps\pushotool\WEB-INF"路径下呀?Tomcat怎么不去找呢?这就是当初我第一次见这个异常时的情景.后来经高人指点后把WEB-INF作为source folderlink 进去了.
注意在link这个WEB-INF时直接不会成功的,得通过Add Source的方式进行,同样也会有红叉作为警告,这时就要用到LinkSource对话框里的Exclusion patterns把那些不相关的文件夹给exclusion出去,这时就是把WEB-INF下的layout,lib和pages过滤出去.
link进去后,上面的那个关于application.xml的问题没有了.这是为什么呢?在Tomcat启动时不找那些配置文件,却是在中间某一过程中找,后来看到BeanUtil.java中有下面一段话:
private static String[] xmlPath = new String[] {"applicationContext.xml", "pushtool-dao.xml", "pushtool-messages.xml", "pushtool-cacheContext.xml"};
public static Object getBean(String beanName) {
if(appCtx == null) {
logger.info("ApplicationContext not initialized, init now...");
appCtx = new ClassPathXmlApplicationContext(xmlPath);
}
return appCtx.getBean(beanName);
}
呵呵,写的有些纳闷,要在中途的这个时候来初始化ApplicationContext,那么正常应该是什么样子的呢?
先放下这个问题,转到正常的步骤来,输入Username和password后又出现异常了,异常信息大概是这样的:Name jdbc is not bound in this Context,Error creating bean with name 'dataSource' defined in class path resource [applicationContext.xml]
原因是这时系统要从数据库里查一些数据.这样就进入那些头痛的DataSource和JNDI配置功能了.好在我已把这个配置搞定了,现在也只是根据问题现象把那些配置串起来.
下一篇中我将把在Tomcat里如何配置JNDI/JDBC整理一下.
分享到:
相关推荐
在Eclipse中配置Ant组织的Project是开发Java Web应用程序时常用的一种方法,它可以帮助开发者更加高效地管理和构建项目。本文将详细讲解如何在Eclipse中配置Ant,以及如何结合Tomcat服务器来设置JNDI(Java Naming ...
在 Eclipse 中集成 Ant,可以通过右键点击项目,选择“构建路径”>“配置构建路径”>“构建配置”>“新建”>“Ant 构建文件”,然后选择你的 build.xml 文件。这样,你就可以在 Eclipse 内部直接运行 Ant 目标。 ...
4. **设置自动构建**:在Eclipse的首选项中,选择“项目”>“构建”,启用“自动构建”选项,这样每次代码更改后,Eclipse都会根据`.project`文件中配置的构建器自动执行Ant任务。 通过这样的配置,开发者可以方便...
### Eclipse中使用Ant详解 #### 引言 在软件开发领域,自动化构建工具的重要性不言而喻,它们能够显著提高开发效率,减少人为错误。Ant作为一款基于Java平台的批处理构建工具,自诞生以来便受到广泛欢迎。本文将...
2. **轻量级**:相对于其他构建工具而言,Ant的学习成本较低,配置简单明了。 3. **高度可定制**:通过丰富的任务(task)和属性(property),用户可以根据项目需求自由地定制构建流程。 4. **社区支持广泛**:作为...
2. **Eclipse中配置Ant**:启动Eclipse,进入“Window”菜单,选择“Preferences”,然后找到“Ant”选项。在这里,可以配置Ant的安装位置,使Eclipse能够识别它。 3. **创建或导入Ant构建文件**:每个Ant项目都有...
### Eclipse中Ant的配置与测试 #### 一、Ant简介 Ant是一款强大的自动化构建工具,主要应用于Java项目中。它可以高效地完成项目的编译、测试、部署等任务,极大地提升了开发者的生产力。对于初学者来说,Ant的学习...
eclipse虽然用的比较少,但是在一些古老的项目上还会用到滴,其中最麻烦的事情就是打带签名包的问题,不太方便,下面通过本文给大家记录下配置ant,自动打包带签名apk的过程,作为备份。(PC环境为MAC) 1,第一步得安...
Eclipse中,可以在项目属性中配置Ant builder,使其在构建过程中使用自定义的`build.xml`文件。这样,平时的调试工作可以交由Eclipse的Java Builder处理,而部署或发布时,利用Ant实现自动化构建。 此外,对于更...
6. **.classpath**和.project文件(如果存在):这些可能是Eclipse等IDE的项目配置文件,帮助在IDE中管理和构建项目。 使用Ant构建Java项目时,开发者通常会遵循以下步骤: 1. **配置build.xml**:根据项目需求,...
2. **启用Proguard**:在Eclipse中,打开项目的`project.properties`文件,添加以下行来启用Proguard: ``` proguard.config=proguard-project.txt ``` 这行代码告诉Ant使用名为`proguard-project.txt`的配置...
此外,为了自动化整个流程,你可能需要集成Ant到Eclipse中,通过Eclipse的外部工具配置来运行Ant脚本。 总结来说,这个过程涵盖了从源代码管理到Web应用部署的整个生命周期。开发者可以通过修改`build.xml`文件定制...
这些文档,如“在Eclipse中集成Ant配置.doc”、“Ant的配置.doc”、“java_ant详解.doc”、“Ant配置实例.doc”和“ant的安装与配置.docx”,会进一步详细介绍如何编写Ant配置文件,解决实际问题,以及如何在开发...
### Eclipse中Ant的配置与测试详解 #### 一、引言 随着软件开发项目的日益复杂化,自动化构建工具成为提高开发效率的关键因素之一。Apache Ant作为一款强大的Java平台下的自动化构建工具,它能够帮助开发者自动完成...
本文将详细介绍如何在Eclipse集成开发环境中配置并使用Ant。 #### 二、Ant 的基本概念 1. **Ant**:一种基于Java的自动化构建工具,用于自动化执行如编译、测试、部署等常规任务。 2. **构建脚本**:通常指`build....