I am learning how to create java webapps for JBossAS 5.1.0, and I am trying to create a very simple jsp web application on JBossAS5 using a JNDI data source to access data.
When I try to open a connection, I get this exception:
21:42:52,834 ERROR [STDERR] Cannot get connection: org.jboss.util.NestedSQLException: Unable to get managed connection for hedgehogDB; - nested throwable: (javax.resource.ResourceException: Unable to get managed connection for hedgehogDB)
The data source is deployed normally, I see it in the jmx console, and the database files are created normally.
Java code that throws an exception:
static public Connection getHedgehogConnection() { Connection result = null; try { String DS_Context = "java:comp/env/jdbc/hedgehogDB"; Context initialContext = new InitialContext(); if ( initialContext == null) log("JNDI problem. Cannot get InitialContext."); DataSource datasource = (DataSource)initialContext.lookup(DS_Context); if (datasource != null) result = datasource.getConnection(); else log("Failed: datasource was null"); } catch(Exception ex) { log("Cannot get connection: " + ex); } return result; }
web.xml:
<web-app> <resource-ref> <res-ref-name>jdbc/hedgehogDB</res-ref-name> <res-type>javax.sql.DataSource</res-type> <res-auth>Container</res-auth> </resource-ref> </web-app>
JBoss-web.xml:
<jboss-web> <resource-ref> <res-ref-name>jdbc/hedgehogDB</res-ref-name> <jndi-name>java:/hedgehogDB</jndi-name> </resource-ref> </jboss-web>
hedgehogdb-ds.xml
<datasources> <local-tx-datasource> <jndi-name>hedgehogDB</jndi-name> <connection-url>jdbc:hsqldb:${jboss.server.data.dir}${/}hypersonic${/}hedgehogDB</connection-url> <driver-class>org.hsqldb.jdbcDriver</driver-class> <user-name>sa</user-name> <password></password> <min-pool-size>5</min-pool-size> <max-pool-size>20</max-pool-size> <idle-timeout-minutes>0</idle-timeout-minutes> <track-statements/> <security-domain>HsqlDbRealm</security-domain> <prepared-statement-cache-size>32</prepared-statement-cache-size> <metadata> <type-mapping>Hypersonic SQL</type-mapping> </metadata> <depends>jboss:service=Hypersonic,database=hedgehogDB</depends> </local-tx-datasource> <mbean code="org.jboss.jdbc.HypersonicDatabase" name="jboss:service=Hypersonic,database=hedgehogDB"> <attribute name="Database">hedgehogDB</attribute> <attribute name="InProcessMode">true</attribute> </mbean> </datasources>
This is my first time in this environment, and I suspect that I am missing something really elementary.
Dana
source share