2012-04-13 3 views
0

Я более чем неопытен с Apache Tomcat, так что простите меня, если это тривиальный вопрос, который я задаю.Определение ресурсов JNDI в Apache Tomcat 6

Моя задача - изменить довольно большую программу, чтобы она использовала соединение Tomcat вместо своего собственного компонента, так что вам не нужно перестраивать код при изменении базы данных.

Это первоначальное определение боба (немного изменен - ​​пароли и такой ...):

<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, но я не знаю, где именно. Может ли это быть проблема?

+0

Я нашел это другое решение: http://stackoverflow.com/questions/9841109/how-to-change-spring-to-use-datasource-from-tomcat-vs-basicdatasource, но он также дает мне сообщения об ошибках (Ошибка listenerStart), когда я пытаюсь это сделать. – Mahawkee

ответ

2

Сначала откат ваших 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 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 и proxy unterface.

Надеюсь, что это сработает для вас!

+0

Спасибо, я попробовал это, сначала так, как ты это сказал, тогда я включил первую часть в контекст.xml Apache. Оба раза программа сообщила мне об этом сообщении об ошибке: 13.04.2012 12:37:32 org.apache.catalina.core.StandardContext start SCHWERWIEGEND: Ошибка listenerStart 13.04.2012 12:37:32 org.apache.catalina. core.StandardContext start SCHWERWIEGEND: запуск контекста [/ rotrajServer] завершился неудачно из-за предыдущих ошибок ....... – Mahawkee

+0

Не могли бы вы дать мне больше из stacktrace plz? –

+0

Это как можно больше я могу написать здесь: 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 start SEVERE: запуск контекста [/ myServer] не выполнен из-за предыдущих ошибок 16.04.2012 09:59:11 org.apache.catalina.loader.WebappClassLoader clearReferencesJdbc SEVERE: веб-приложение [/ myServer] зарегистрировало драйвер JDBC [com.ibm.as400.access.AS400JDBCDriver], но не удалось отменить его, когда веб-приложение было остановлено. Чтобы предотвратить утечку памяти, драйвер JDBC был принудительно незарегистрирован. – Mahawkee

Смежные вопросы