天天看点

eclipse mysql jndi_Eclipse +Tomcat配置JNDI数据源

以下是具体配置的步骤:

1.首先配置Tomcat下的jndi数据源。具体存放目录apache-tomcat-7.0.59\conf\Catalina\localhost 下

osh.xml

name="jdbc/osh" auth="Container"

type="javax.sql.DataSource"

driverClassName="oracle.jdbc.driver.OracleDriver"

url="jdbc:oracle:thin:@(DESCRIPTION=(ADDRESS_LIST =(ADDRESS=(PROTOCOL=TCP)(HOST=localhost)(PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=orcl)(SERVER=DEDICATED)))"

validationQuery="select 0 from DUAL"

username="olay"

password="123456"

maxActive="100"

maxIdle="50"

maxWait="10000"

removeAbandoned="true"

removeAbandonedTimeout="60"/>

(2)在tomcat的安装文件中lib目录下放入数据库驱动jar。

(3)spring的applicationContext.xml中配置datasource:

java:comp/env/jdbc/osh

注意Vlaue属性中必须加入java:comp/env,后面才是servers中的Resource 的name

(4)web.xml(这一步在eclipse项目要配上,不然找不到数据源)

Oracle Connection

jdbc/osh

javax.sql.DataSource

Container

在配置过程中,本人遇到下面问题,现在贴出来,分享一下。

同样的配置,同样的方法。Myeclipse项目启动正常,但是eclipse项目启动报错,错误入下:

org.springframework.beans.factory.BeanCreationException: Error creating bean with name ‘OSHDatasource‘ defined in ServletContext resource [/osh/config/osh-servlet.xml]: Invocation of init method failed; nested exception is javax.naming.NameNotFoundException: Name [jdbc/osh] is not bound in this Context. Unable to find [jdbc].

错误很明显是找不到jdbc/osh,导致获取不到数据源。 很郁闷的是myclipse下没问题。纠结了好久,终于找到问题所在。Eclipse环境下在不到tomcat的jndi数据源。 因此要在web.xml文件加上以下代码

Oracle Connection

jdbc/osh

javax.sql.DataSource

Container

这样就可以找到tomcat的数据源,问题解决了。

原文:http://blog.csdn.net/zhixinhuacom/article/details/46496193