2012-01-21 12 views
9

Nie mogę pracować, aby uzyskać połączenie z DataSource uzyskanych z JNDI w Tomcat 7.0, w wyniku błędu tak:Konfigurowanie JNDI źródła danych Oracle w Tomcat

org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot create JDBC driver of cla 
ss '' for connect URL 'null' 

mam zrobić na wiele sposobów, następujące dokument i sugestie innych osób, ale wciąż nie są w stanie tego naprawić. Oto moje ustawienia:

W web.xml:

<resource-ref> 
    <description>MyDataSource</description> 
    <res-ref-name>jdbc/MyDataSource</res-ref-name> 
    <res-type>javax.sql.DataSource</res-type> 
    <res-auth>Container</res-auth> 
</resource-ref> 

W context.xml:

<Context> 
    <Resource name="jdbc/MyDataSource" auth="Container" type="javax.sql.DataSource" 
       maxActive="100" maxIdle="30" maxWait="10000" 
       username="abc" password="abc" driverClassName="oracle.jdbc.OracleDriver" 
       url="jdbc:oracle:thin:@123.123.123.123:1521:xe"/> 
       <!-- // tried both driver class names but all not work driverClassName="oracle.jdbc.driver.OracleDriver" --> 
</Context> 

Również próbowałem umieścić, że w server.xml, również nie działa

<Resource name="jdbc/MyDataSource" auth="Container" type="javax.sql.DataSource" 
    driverClassName="oracle.jdbc.driver.OracleDriver" 
    url="jdbc:oracle:thin:@123.123.123.123:1521:xe" 
    servicename="MyDataSource" username="abc" password="abc" 
    maxActive="20" maxIdle="10" maxWait="20000"/> 

<ResourceParams name="jdbc/MyDataSource"> 
    <parameter> 
     <name>user</name> 
     <value>abc</value> 
    </parameter> 
    <parameter> 
     <name>password</name> 
     <value>abc</value> 
    </parameter> 
    <parameter> 
     <name>driverClassName</name> 
     <value>oracle.jdbc.driver.OracleDriver</value> 
    </parameter> 
</ResourceParams> 

Umieścić klasy 12.jar oraz ojdbc14.jar w Tomcat 7.0 \ lib

Czy ktoś może wskazać mi właściwą drogę?

Zmarnowałem tak dużo czasu na tę konfigurację, ale nadal nie mogę jej uruchomić. Z góry dziękuję!

John


Śledzenie stosu jak poniżej:

DS: [email protected] 
org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot create JDBC driver of class '' for connect URL 'null' 
    at org.apache.tomcat.dbcp.dbcp.BasicDataSource.createConnectionFactory(BasicDataSource.java:1452) 
    at org.apache.tomcat.dbcp.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:1371) 
    at org.apache.tomcat.dbcp.dbcp.BasicDataSource.getConnection(BasicDataSource.java:1044) 
    at DBTest.doGet(DBTest.java:70) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:621) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:722) 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:224) 
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:169) 
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472) 
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168) 
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98) 
    at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:928) 
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) 
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407) 
    at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:987) 
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:539) 
    at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:298) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(Unknown Source) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) 
    at java.lang.Thread.run(Unknown Source) 
Caused by: java.lang.NullPointerException 
    at sun.jdbc.odbc.JdbcOdbcDriver.getProtocol(Unknown Source) 
    at sun.jdbc.odbc.JdbcOdbcDriver.knownURL(Unknown Source) 
    at sun.jdbc.odbc.JdbcOdbcDriver.acceptsURL(Unknown Source) 
    at java.sql.DriverManager.getDriver(Unknown Source) 
    at org.apache.tomcat.dbcp.dbcp.BasicDataSource.createConnectionFactory(BasicDataSource.java:1437) 
    ... 21 more 

A oto kod, wyjątek na ds.getConnection. (Nie jest to typowy sposób uzyskania DS, bcz musi pasować do sposobu WebSphere ...)

Properties env = new Properties(); 
env.put(Context.INITIAL_CONTEXT_FACTORY, "org.apache.naming.java.javaURLContextFactory"); 
initCtx = new InitialContext(env); 
DataSource ds = (DataSource) initCtx.lookup("java:comp/env/jdbc/MyDataSource"); 
System.err.println("DS: " + ds.toString()); 
Connection conn = ds.getConnection(); 
+0

John, Uprzejmie po pełnym StackTrace. –

+0

@DarkRider, stacktrace dodaj, również dołączony fragment kodu – John

Odpowiedz

2

Przeszedłem przez ten sam scenariusz z powrotem.

Ten link Here pomógł mi.

+0

dzięki za pomoc, przeczytałem ten link wcześniej, podążałem wieloma sugestiami tam, ale wciąż ten sam problem ... – John

4

Zdałem sobie sprawę, że dwukrotnie zdefiniowałem zasób, raz w moim TOMCAT_HOME/conf/context.xml oraz w moim applicationPath/META-INF/context.xml. Po usunięciu zasobu z TOMCAT_HOME/conf/context.xml wszystko działało świetnie.

Powiązane problemy