Skip to Main Content

Java EE (Java Enterprise Edition) General Discussion

Announcement

For appeals, questions and feedback about Oracle Forums, please email oracle-forums-moderators_us@oracle.com. Technical questions should be asked in the appropriate category. Thank you!

ejbs calls between weblogic servers

843829Oct 13 2003 — edited Nov 24 2003
Hi,

I'm trying to get a stateless EJB to make calls to another stateless EJB running in a different container in a different weblogic server.
I've set up a simple test, where a client calls a method on test EJB 1 in weblogic server 1, which itself makes a call to test EJB 2 in weblogic server 2.
Both EJBs are extremely simple. EJB 1 simply contains one method that prints out some debug, gets the JNDI context of server 2, gets the remote interface of EJB 2 and calls a method on it, which simply prints out some debug.
This simple example works perfectly providing the trans-attribute tag in the ejb-jar.xml deployment descriptor is set to "NotSupported". If I give any transactionl properties to either EJB, I get the below exception.
I need to make these EJBs transactional. How do I set the trans-attribute tags? Can anyone help please?

thanks

javax.transaction.TransactionRolledbackException: Current server is the coordinator and transaction is not found. It was probably rolled back and forgotten already.

Start server side stack trace:
javax.transaction.TransactionRolledbackException: Current server is the coordinator and transaction is not found. It was probably rolled back and forgotten already.
at weblogic.transaction.internal.TransactionManagerImpl.receiveRequest(TransactionManagerImpl.java:1239)
at weblogic.rmi.internal.BasicServerRef.dispatch(BasicServerRef.java:232)
at weblogic.rmi.internal.BasicServerRef.invoke(BasicServerRef.java:272)
at weblogic.rjvm.RJVMImpl.dispatchRequest(RJVMImpl.java:724)
at weblogic.rjvm.RJVMImpl.dispatch(RJVMImpl.java:655)
at weblogic.rjvm.ConnectionManagerServer.handleRJVM(ConnectionManagerServer.java:194)
at weblogic.rjvm.ConnectionManager.dispatch(ConnectionManager.java:777)
at weblogic.rjvm.t3.T3JVMConnection.dispatch(T3JVMConnection.java:495)
at weblogic.socket.NTSocketMuxer.processSockets(NTSocketMuxer.java:664)
at weblogic.socket.SocketReaderRequest.execute(SocketReaderRequest.java:23)
at weblogic.kernel.ExecuteThread.execute(ExecuteThread.java:153)
at weblogic.kernel.ExecuteThread.run(ExecuteThread.java:134)
End server side stack trace

at weblogic.rmi.internal.BasicOutboundRequest.sendReceive(BasicOutboundRequest.java:109)
at weblogic.rmi.cluster.ReplicaAwareRemoteRef.invoke(ReplicaAwareRemoteRef.java:262)
at weblogic.rmi.cluster.ReplicaAwareRemoteRef.invoke(ReplicaAwareRemoteRef.java:229)
at com.retailexp.tests.ejb.testbeandelegates.EJBWhateverBean_g8k0sl_HomeImpl_WLStub.create(Unknown Source)
at com.retailexp.tests.ejb.testbeandelegates.EJBContainerCommTestBean.getVal(EJBContainerCommTestBean.java:44)
at com.retailexp.tests.ejb.testbeandelegates.EJBContainerCommTestBean_1hxi1q_EOImpl.getVal(EJBContainerCommTestBean_1hxi1q_EOImpl.java:45)
at com.retailexp.tests.ejb.testbeandelegates.EJBContainerCommTestBean_1hxi1q_EOImpl_WLSkel.invoke(Unknown Source)
at weblogic.rmi.internal.BasicServerRef.invoke(BasicServerRef.java:362)
at weblogic.rmi.cluster.ReplicaAwareServerRef.invoke(ReplicaAwareServerRef.java:114)
at weblogic.rmi.internal.BasicServerRef$1.run(BasicServerRef.java:313)
at weblogic.security.service.SecurityServiceManager.runAs(SecurityServiceManager.java:785)
at weblogic.rmi.internal.BasicServerRef.handleRequest(BasicServerRef.java:308)
at weblogic.rmi.internal.BasicExecuteRequest.execute(BasicExecuteRequest.java:30)
at weblogic.kernel.ExecuteThread.execute(ExecuteThread.java:153)
at weblogic.kernel.ExecuteThread.run(ExecuteThread.java:134)
<13-Oct-2003 15:44:05 BST> <Error> <EJB> <010026> <Exception during commit of transaction 0:b3986dcc02e33667: javax.transaction.SystemException: Commit can be issued only when there are no requests awaiting responses. Currently there is one such request
at weblogic.transaction.internal.TransactionImpl.abort(TransactionImpl.java:989)
at weblogic.transaction.internal.TransactionImpl.enforceCheckedTransaction(TransactionImpl.java:1499)
at weblogic.transaction.internal.TransactionImpl.checkIfCommitPossible(TransactionImpl.java:1477)
at weblogic.transaction.internal.ServerTransactionImpl.internalCommit(ServerTransactionImpl.java:230)
at weblogic.transaction.internal.ServerTransactionImpl.commit(ServerTransactionImpl.java:208)
at weblogic.ejb20.internal.BaseEJBObject.postInvoke(BaseEJBObject.java:278)
at com.retailexp.tests.ejb.testbeandelegates.EJBContainerCommTestBean_1hxi1q_EOImpl.getVal(EJBContainerCommTestBean_1hxi1q_EOImpl.java:55)
at com.retailexp.tests.ejb.testbeandelegates.EJBContainerCommTestBean_1hxi1q_EOImpl_WLSkel.invoke(Unknown Source)
at weblogic.rmi.internal.BasicServerRef.invoke(BasicServerRef.java:362)
at weblogic.rmi.cluster.ReplicaAwareServerRef.invoke(ReplicaAwareServerRef.java:114)
at weblogic.rmi.internal.BasicServerRef$1.run(BasicServerRef.java:313)
at weblogic.security.service.SecurityServiceManager.runAs(SecurityServiceManager.java:785)
at weblogic.rmi.internal.BasicServerRef.handleRequest(BasicServerRef.java:308)
at weblogic.rmi.internal.BasicExecuteRequest.execute(BasicExecuteRequest.java:30)
at weblogic.kernel.ExecuteThread.execute(ExecuteThread.java:153)
at weblogic.kernel.ExecuteThread.run(ExecuteThread.java:134)
--------------- nested within: ------------------
weblogic.transaction.RollbackException: Commit can be issued only when there are no requests awaiting responses. Currently there is one such request - with nested exception:
[javax.transaction.SystemException: Commit can be issued only when there are no requests awaiting responses. Currently there is one such request]
at weblogic.transaction.internal.TransactionImpl.throwRollbackException(TransactionImpl.java:1561)
at weblogic.transaction.internal.ServerTransactionImpl.internalCommit(ServerTransactionImpl.java:284)
at weblogic.transaction.internal.ServerTransactionImpl.commit(ServerTransactionImpl.java:208)
at weblogic.ejb20.internal.BaseEJBObject.postInvoke(BaseEJBObject.java:278)
at com.retailexp.tests.ejb.testbeandelegates.EJBContainerCommTestBean_1hxi1q_EOImpl.getVal(EJBContainerCommTestBean_1hxi1q_EOImpl.java:55)
at com.retailexp.tests.ejb.testbeandelegates.EJBContainerCommTestBean_1hxi1q_EOImpl_WLSkel.invoke(Unknown Source)
at weblogic.rmi.internal.BasicServerRef.invoke(BasicServerRef.java:362)
at weblogic.rmi.cluster.ReplicaAwareServerRef.invoke(ReplicaAwareServerRef.java:114)
at weblogic.rmi.internal.BasicServerRef$1.run(BasicServerRef.java:313)
at weblogic.security.service.SecurityServiceManager.runAs(SecurityServiceManager.java:785)
at weblogic.rmi.internal.BasicServerRef.handleRequest(BasicServerRef.java:308)
at weblogic.rmi.internal.BasicExecuteRequest.execute(BasicExecuteRequest.java:30)
at weblogic.kernel.ExecuteThread.execute(ExecuteThread.java:153)
Comments
Locked Post
New comments cannot be posted to this locked post.
Post Details
Locked on Dec 22 2003
Added on Oct 13 2003
6 comments
1,546 views