[jboss-user] [EJB 3.0] - problems working with XA datasource

mreis do-not-reply at jboss.com
Tue Aug 14 05:08:39 EDT 2007


Dear all,


in my EJB3 SLSB (exposed as a WebService) I'd like to contact a Jackrabbit XA datasource, operate on it, and commit changes.

The datasource is configured in server/default/deploy/jcr-ds.xml:

  |    <connection-factories>
  |        <tx-connection-factory>
  |            <jndi-name>jcr/local</jndi-name>
  |            <xa-transaction/>
  |            <rar-name>jackrabbit-jca-1.3.1.rar</rar-name>
  |            <connection-definition>javax.jcr.Repository</connection-definition>
  |            <config-property name="homeDir" type="java.lang.String">${jboss.server.data.dir}${/}jackrabbit</config-property>
  |            <config-property name="configFile" type="java.lang.String">classpath:repository.xml</config-property>
  |            <config-property name="bindSessionToTransaction" type="java.lang.Boolean">true</config-property>
  |        </tx-connection-factory>
  |    </connection-factories> 
  | 

my SLSB looks like:
the field that contains the connection factory:

  |    @Resource(mappedName="java:jcr/local", type=javax.jcr.Repository.class, authenticationType=javax.annotation.Resource.AuthenticationType.CONTAINER) Repository repo;
  | 
the method (excerpt) where operations are executed on the XA connection:

  |            Credentials cred = new SimpleCredentials(path.getUsername(), path.getPassword());
  |            session = repo.login(cred, null);
  |            Node root = session.getRootNode();
  |            Node child = root.hasNode(path.getRelativePath()) ? root.getNode(path.getRelativePath()) : createFilePath(root, path.getPathParts(), path.getObjectName());
  |            FileTypeResolver ftr = FileTypeResolver.instantiate();
  |            child.setProperty("jcr:mimeType", ftr.getMIMEType(obj));
  |            child.setProperty("jcr:data", new FileInputStream(obj));
  |            Calendar rightNow = Calendar.getInstance();
  |            child.setProperty("jcr:lastModified", rightNow);
  |            session.save(); 
  | 
I annotated the method with:

  |    @TransactionAttribute(TransactionAttributeType.REQUIRED)
  | 
This should be the default setting AFAIK, but who knows ... 

Debugging my code I found out that everything works fine until and after session.save() - When the method returns however it seems that a commit takes place (calling XASessionImpl.end()) and this commit is not successful due to a missing transaction:

  | 143394 [http-0.0.0.0-8080-3] ERROR org.jboss.ws.core.jaxws.SOAPFaultHelperJAXWS  - SOAP request exception
  | java.lang.RuntimeException: org.jboss.tm.JBossRollbackException: Unable to commit, tx=TransactionImpl:XidImpl[FormatId=257,
  | GlobalId=dme018/14, BranchQual=, localId=14] status=STATUS_NO_TRANSACTION; - nested throwable: (javax.transaction.xa.XAExc
  | eption)
  |        at org.jboss.aspects.tx.TxPolicy.handleEndTransactionException(TxPolicy.java:198)
  |        at org.jboss.aspects.tx.TxPolicy.endTransaction(TxPolicy.java:180)
  |        at org.jboss.aspects.tx.TxPolicy.invokeInOurTx(TxPolicy.java:87)
  |        at org.jboss.aspects.tx.TxInterceptor$Required.invoke(TxInterceptor.java:191)
  |        at org.jboss.aop.joinpoint.MethodInvocation.invokeNext(MethodInvocation.java:101)
  |        at org.jboss.aspects.tx.TxPropagationInterceptor.invoke(TxPropagationInterceptor.java:76)
  |        at org.jboss.aop.joinpoint.MethodInvocation.invokeNext(MethodInvocation.java:101)
  |        at org.jboss.ejb3.stateless.StatelessInstanceInterceptor.invoke(StatelessInstanceInterceptor.java:62)
  |        at org.jboss.aop.joinpoint.MethodInvocation.invokeNext(MethodInvocation.java:101)
  |        at org.jboss.aspects.security.AuthenticationInterceptor.invoke(AuthenticationInterceptor.java:77)
  |        at org.jboss.ejb3.security.Ejb3AuthenticationInterceptor.invoke(Ejb3AuthenticationInterceptor.java:102)
  |        at org.jboss.aop.joinpoint.MethodInvocation.invokeNext(MethodInvocation.java:101)
  |        at org.jboss.ejb3.ENCPropagationInterceptor.invoke(ENCPropagationInterceptor.java:47)
  |        at org.jboss.aop.joinpoint.MethodInvocation.invokeNext(MethodInvocation.java:101)
  |        at org.jboss.ejb3.asynchronous.AsynchronousInterceptor.invoke(AsynchronousInterceptor.java:106)
  |        at org.jboss.aop.joinpoint.MethodInvocation.invokeNext(MethodInvocation.java:101)
  |        at org.jboss.ejb3.stateless.StatelessContainer.localInvoke(StatelessContainer.java:211)
  |        at org.jboss.ejb3.stateless.StatelessContainer.localInvoke(StatelessContainer.java:173)
  |        at org.jboss.ws.integration.jboss42.ServiceEndpointInvokerEJB3.invokeServiceEndpoint(ServiceEndpointInvokerEJB3.jav
  | a:114)
  |        at org.jboss.ws.core.server.AbstractServiceEndpointInvoker.invoke(AbstractServiceEndpointInvoker.java:173)
  |        at org.jboss.ws.core.server.ServiceEndpoint.handleRequest(ServiceEndpoint.java:204)
  |        at org.jboss.ws.core.server.ServiceEndpointManager.processSOAPRequest(ServiceEndpointManager.java:440)
  |        at org.jboss.ws.core.server.AbstractServiceEndpointServlet.doPost(AbstractServiceEndpointServlet.java:114)
  |        at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
  |        at org.jboss.ws.core.server.AbstractServiceEndpointServlet.service(AbstractServiceEndpointServlet.java:75)
  |        at javax.servlet.http.HttpServlet.service(HttpServlet.java:810)
  |        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:252)
  |        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:173)
  |        at org.jboss.web.tomcat.filters.ReplyHeaderFilter.doFilter(ReplyHeaderFilter.java:96)
  |        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:202)
  |        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:173)
  |        at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:213)
  |        at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:178)
  |        at org.jboss.web.tomcat.security.SecurityAssociationValve.invoke(SecurityAssociationValve.java:175)
  |        at org.jboss.web.tomcat.security.JaccContextValve.invoke(JaccContextValve.java:74)
  |        at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:126)
  |        at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:105)
  |        at org.jboss.web.tomcat.tc5.jca.CachedConnectionValve.invoke(CachedConnectionValve.java:156)
  |        at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:107)
  |        at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:148)
  |        at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:869)
  |        at org.apache.coyote.http11.Http11BaseProtocol$Http11ConnectionHandler.processConnection(Http11BaseProtocol.java:66
  | 4)
  |        at org.apache.tomcat.util.net.PoolTcpEndpoint.processSocket(PoolTcpEndpoint.java:527)
  |        at org.apache.tomcat.util.net.MasterSlaveWorkerThread.run(MasterSlaveWorkerThread.java:112)
  |        at java.lang.Thread.run(Thread.java:595)
  | Caused by: org.jboss.tm.JBossRollbackException: Unable to commit, tx=TransactionImpl:XidImpl[FormatId=257, GlobalId=dme018/
  | 14, BranchQual=, localId=14] status=STATUS_NO_TRANSACTION; - nested throwable: (javax.transaction.xa.XAException)
  |        at org.jboss.tm.TransactionImpl.commit(TransactionImpl.java:372)
  |        at org.jboss.tm.TxManager.commit(TxManager.java:240)
  |        at org.jboss.aspects.tx.TxPolicy.endTransaction(TxPolicy.java:175)
  |        ... 43 more
  | Caused by: javax.transaction.xa.XAException
  |        at org.apache.jackrabbit.core.XASessionImpl.end(XASessionImpl.java:279)
  |        at org.apache.jackrabbit.jca.TransactionBoundXAResource.end(TransactionBoundXAResource.java:46)
  |        at org.jboss.tm.TransactionImpl$Resource.endResource(TransactionImpl.java:2143)
  |        at org.jboss.tm.TransactionImpl$Resource.endResource(TransactionImpl.java:2118)
  |        at org.jboss.tm.TransactionImpl.endResources(TransactionImpl.java:1462)
  |        at org.jboss.tm.TransactionImpl.beforePrepare(TransactionImpl.java:1116)
  |        at org.jboss.tm.TransactionImpl.commit(TransactionImpl.java:324)
  |        ... 45 more 
  | 

This topic may fit into the JCA or Transactions Forums as well, but it seems that it is somehow closely related to EJB3, since the same code works well from within a JSP page.

Any help/guidance is highly appreciated.


kind regards,
Markus

View the original post : http://www.jboss.com/index.html?module=bb&op=viewtopic&p=4073888#4073888

Reply to the post : http://www.jboss.com/index.html?module=bb&op=posting&mode=reply&p=4073888



More information about the jboss-user mailing list