Eclipse里配置Ant 组织的Project(2)

本文针对Tomcat服务器启动过程中遇到的各类异常进行了详细的分析与解决,包括log4j配置文件缺失、项目名称冲突及配置文件applicationContext.xml未找到等问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

接着上一篇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整理一下.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值