【问题标题】:JNDI Resource Definition in Apache Tomcat 6Apache Tomcat 6 中的 JNDI 资源定义
【发布时间】:2012-04-13 08:47:22
【问题描述】:

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

【问题讨论】:

标签: spring tomcat6 jndi


【解决方案1】:

首先,在您的 tomcat 和/或中回滚您的 context.xmlserver.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 和代理接口。

希望它对你有用!

【讨论】:

  • 谢谢,我试过了,先按照你说的方式,然后我把第一部分放到了Apache的context.xml中。程序两次都给了我这个错误消息:13.04.2012 12:37:32 org.apache.catalina.core.StandardContext start SCHWERWIEGEND: Error listenerStart 13.04.2012 12:37:32 org.apache.catalina.core.StandardContext start SCHWERWIEGEND:上下文 [/rotrajServer] 启动失败,由于以前的错误......
  • 你能给我更多的堆栈跟踪吗?
  • 这就是我可以在这里发布的内容:16.04.2012 09:59:11 org.apache.catalina.core.StandardContext start SEVERE: Error listenerStart 16.04.2012 09:59:11 org .apache.catalina.core.StandardContext 启动严重:上下文 [/myServer] 启动失败,由于先前的错误 16.04.2012 09:59:11 org.apache.catalina.loader.WebappClassLoader clearReferencesJdbc 严重:Web 应用程序 [/myServer] 已注册JDBC 驱动程序 [com.ibm.as400.access.AS400JDBCDriver] 但在 Web 应用程序停止时未能取消注册。为防止内存泄漏,已强制注销 JDBC Driver。
  • 从头开始...我似乎在其他地方搞砸了。我从备份中获取了旧文件并重新开始使用您的解决方案,然后它起作用了。非常感谢!
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-02-07
  • 2014-04-18
  • 2018-05-16
  • 2014-12-24
  • 1970-01-01
相关资源
最近更新 更多