I'm getting the same things with a jtds datasource pointing at SQL
Server, as in:

http://issues.apache.org/activemq/browse/AMQ-711

anyone?

On 5/31/06, Adrian Tarau <[EMAIL PROTECTED]> wrote:
Anybody?

Adrian Tarau wrote:
> I got this exception when ActiveMQ is initialized with an Oracle
> datasource.
>
> Caused by: java.io.IOException: You cannot commit with autocommit set!
>    at
> org.apache.activemq.util.IOExceptionSupport.create(IOExceptionSupport.java:42)
>
>    at
> 
org.apache.activemq.store.jdbc.TransactionContext.close(TransactionContext.java:125)
>
>    at
> 
org.apache.activemq.store.jdbc.JDBCPersistenceAdapter.createAdapter(JDBCPersistenceAdapter.java:253)
>
>    at
> 
org.apache.activemq.store.jdbc.JDBCPersistenceAdapter.getAdapter(JDBCPersistenceAdapter.java:213)
>
>    at
> 
org.apache.activemq.store.jdbc.JDBCPersistenceAdapter.start(JDBCPersistenceAdapter.java:139)
>
>    at
> 
org.apache.activemq.broker.BrokerService.createRegionBroker(BrokerService.java:930)
>
>    at
> org.apache.activemq.broker.BrokerService.createBroker(BrokerService.java:888)
>
>    at
> org.apache.activemq.broker.BrokerService.getBroker(BrokerService.java:458)
>
>    at
> org.apache.activemq.broker.BrokerService.addConnector(BrokerService.java:143)
>
>    at
> org.apache.activemq.broker.BrokerService.addConnector(BrokerService.java:133)
>
>    ... 62 more
> Caused by: java.sql.SQLException: You cannot commit with autocommit set!
>    at
> 
org.jboss.resource.adapter.jdbc.BaseWrapperManagedConnection.jdbcCommit(BaseWrapperManagedConnection.java:434)
>
>    at
> 
org.jboss.resource.adapter.jdbc.WrappedConnection.commit(WrappedConnection.java:331)
>
>    at
> 
org.apache.activemq.store.jdbc.TransactionContext.close(TransactionContext.java:119)
>
>    ... 71 more
>
> Following the exception path I realized that the problem comes from
> the commit in TransactionContext.close().
> As the comment explain nicely there shouldn't be any commit there.
> Any suggestions?
>
>
>
> public void close() throws IOException {
>        if( !inTx ) {
>            try {
>                executeBatch();
>                              /**
>                 * we are not in a transaction so should not be
> committing ??
>                 * This was previously commented out - but had
>                 * adverse affects on testing - so it's back!
>                 *
>                 */
>                try{
>                    executeBatch();
>                } finally {
>                    if (connection != null) {
>                        connection.commit();
>                    }
>                }
>                          } catch (SQLException e) {
>                JDBCPersistenceAdapter.log("Error while closing
> connection: ", e);
>                throw IOExceptionSupport.create(e);
>            } finally {
>                try {
>                    if (connection != null) {
>                        connection.close();
>                    }
>                } catch (Throwable e) {
>                    log.warn("Close failed: "+e.getMessage(), e);
>                } finally {
>                    connection=null;
>                }
>            }
>        }
>    }
>


Reply via email to