0

我对 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>

服务器.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" /> 

上下文.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,但我不知道具体在哪里。这可能是问题吗?

4

1 回答 1

2

首先,在你的 Tomcat 和/或中回滚你的context.xml和。server.xml这是一个工作配置:

src/main/webapp/META-INF在命名中创建一个文件,context.xml其中包含:

<?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:

<bean id="ProjectDS" class="org.springframework.jndi.JndiObjectFactoryBean">
    <property name="jndiName" value="java:comp/env/ProjectDS" />
    <property name="proxyInterface" value="javax.sql.DataSource" />
</bean>

这里的区别是java:comp/env/ProjectDS和代理接口。

希望它对你有用!

于 2012-04-13T09:37:15.763 回答