Apache Tomcat 6中的JNDI资源定义

时间:2012-04-13 08:47:22

标签: spring tomcat6 jndi

我对Apache Tomcat缺乏经验,所以请原谅我这是一个微不足道的问题。

我的任务是更改一个相当大的程序,以便它使用Tomcat的连接而不是它自己的bean,这样你就不必在数据库发生变化时重建代码。

这是原始的bean定义(略有改动 - 密码等等):

<bean id="ProjectDS" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close" scope="singleton">
        <property name="url"
                  value="jdbc:as400://127.0.0.1/TEST2;prompt=false;naming=sql;errors=full;date format=usa;date separator=/;time format=hms;time separator=:;transaction isolation=read committed;"/>
        <property name="driverClassName" value="com.ibm.as400.access.AS400JDBCDriver"/>
        <property name="username" value="asdf"/>
        <property name="password" value="asdf"/>
        <property name="initialSize" value="${ProjectDS.initialSize}"/>
        <property name="maxActive" value="${ProjectDS.maxActive}"/>
        <property name="maxIdle" value="${ProjectDS.maxIdle}"/>
        <property name="minIdle" value="${ProjectDS.minIdle}"/>
        <property name="testOnBorrow" value="${ProjectDS.testOnBorrow}"/>
        <property name="removeAbandoned" value="${ProjectDS.removeAbandoned}"/>
        <property name="removeAbandonedTimeout" value="${ProjectDS.removeAbandonedTimeout}"/>
        <property name="logAbandoned" value="${ProjectDS.logAbandoned}"/>
    </bean>

在阅读了几篇关于Tomcat配置的教程后,我做了以下几点:

新豆:

<bean id="ProjectDS" class="org.springframework.jndi.JndiObjectFactoryBean">
        <property name="jndiName">
            <value>ProjectDS</value>
        </property>
        <property name="resourceRef" value="true"></property>
    </bean>

server.xml:

<Resource name="ProjectDS" global="ProjectDS" auth="Container"
            type="org.apache.commons.dbcp.BasicDataSource"
            driverClassName="com.ibm.as400.access.AS400JDBCDriver"
            url="jdbc:as400://127.0.0.1/TEST2"
            username="asdf"
            password="asdf" /> 

context.xml中:

<WatchedResource>WEB-INF/web.xml</WatchedResource>
    <ResourceLink global="ProjectDS" name="ProjectDS" type="org.apache.commons.dbcp.BasicDataSource"/>

我得到的是:

  

异常处理全局JNDI资源   javax.naming.NamingException:无法创建资源实例

我在某处读到了我不应该将上述内容放入server.xml但放入web.xml,但我不知道究竟在哪里。这可能是问题吗?

1 个答案:

答案 0 :(得分:2)

首先,在您的tomcat中回滚context.xmlserver.xml和/或。这是一个有效的配置:

在名为src/main/webapp/META-INF的{​​{1}}中创建一个包含以下内容的文件:

context.xml

然后,以这种方式编辑你的bean:

<?xml version="1.0" encoding="UTF-8"?>
<Context>
<Resource name="ProjectDS" auth="Container"
            type="javax.sql.DataSource"
            driverClassName="com.ibm.as400.access.AS400JDBCDriver"
            url="jdbc:as400://127.0.0.1/TEST2"
            username="asdf"
            password="asdf" /> 
</Context>

这里的区别是<bean id="ProjectDS" class="org.springframework.jndi.JndiObjectFactoryBean"> <property name="jndiName" value="java:comp/env/ProjectDS" /> <property name="proxyInterface" value="javax.sql.DataSource" /> </bean> 和代理接口。

希望它对你有用!