以前一直用MyEclipse,以后要慢慢学会用eclipse。最开始用的就是myeclipse,直到最近感觉后者更容易让自己了解项目的结构,不多说了,讲问题了!
昨天新检出了一个项目,了解后发现数据库连接方式是jndi建的数据源。没多想先启动了,报错如下:
严重: Context initialization failed
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'dataSource' defined in ServletContext resource [/WEB-INF/classes/applicationContext.xml]: Initialization of bean failed; nested exception is javax.naming.NameNotFoundException: Name jdbc is not bound in this Context
javax.naming.NameNotFoundException: Name jdbc is not bound in this Context
at org.apache.naming.NamingContext.lookup(NamingContext.java:770)
肯定是数据源没找到没连接上了,网上找了很多,大体上说的配置方式是给 /tomcat/conf/server.xml中加数据源(两种方式:方式一,server.xml中项目的context中配;方式二,GlobalNamingResources中配,我两者都试过了),同时给自己的项目web.xml中加
<resource-ref>
<res-auth>Container</res-auth>
<res-ref-name>jndi/jdbc</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
</resource-ref>
后来一直就报下面的错误:
org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot create JDBC driver of class '' for connect URL 'null'
今天来到公司,启动server前publish了一次,就莫名的ok了(最后是搞明白了,因为从web.xml中的配置找数据源时没找到故而报此错,还是说明数据源位置不对)。再试试把web.xml中的那段去了,依然可以!我的理解是配置修改后没有部署到server的问题!
检查方式:看D:\workspace\.metadata\.plugins\org.eclipse.wst.server.core\tmp1\conf中的server.xml是否改过来了,记得把数据源配置在context中!
看来eclipse还是不熟悉惹的祸!
总结:
使用方式一:
只需在tomcat 的server.xml中的项目对应Context中添加数据源即可!若还在web.xml中加resource-ref定会报SQLNestedException的错
使用方式二:
GlobalNamingResources中加了数据源后在在context.xml中加一个 <ResourceLink name="jdbc/zhaopin" global="jdbc/zhaopin" type="javax.sql.DataSource"/>
是将此数据源加进服务的上下文。
其中要在项目web.xml中加resource-ref网上的说法是Tomcat4.x之前的版本是需要的,5.x后就不再需要了。
使用方式三:
后来发现的,就是在数据源加在server.xml所在目录的context.xml中,同时给项目的web.xml中加resource-ref!
感觉还是第一种舒服点!不知道是否还有其它方式了!