2012-04-13 6 views
0

아파치 톰캣에 익숙하지 않아서 사소한 질문이라면 용서해 주겠다.Apache Tomcat 6의 JNDI 리소스 정의

내 작업은 다소 큰 프로그램을 변경하여 데이터베이스가 변경 될 때 코드를 다시 작성할 필요가 없도록 자체 bean 대신 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.xmlserver.xml을 tomcat 및/또는. ,

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

을 그리고 이런 방식으로 콩을 편집 :

포함 context.xml라는 src/main/webapp/META-INF에서 파일을 만듭니다 여기

<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과 여기에 작동하는 구성이다 프록시 인터페이스.

희망은 당신을 위해 일할 것입니다!

+0

고맙다. 처음에 당신이 말했던 방식으로 시도했다. 그런 다음 첫 번째 부분을 Apache의 context.xml에 포함시켰다. 두 번 모두 프로그램이 내게이 오류 메시지를 보냈습니다. 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 심각도 : 오류 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 심각도 : 웹 응용 프로그램 [/ myServer]이 JDBC 드라이버 [com.ibm.as400.access.AS400JDBCDriver]를 등록했지만 웹 응용 프로그램이 중지되었을 때이를 등록 취소하지 못했습니다. 메모리 누수를 방지하기 위해 JDBC 드라이버가 강제로 등록 해제되었습니다. – Mahawkee