我正在运行两个包含无状态会话EJB的glassfish v2域。在少数情况下,一个域中的EJB必须在另一个域中调用一个。在glassfish域之间的IIOP中丢失的异常消息
我的问题是,当被调用的EJB异常中止时,调用者不会收到异常的消息,而是报告一个内部错误,在诊断问题时根本没有任何帮助。发生什么似乎是这样的:
- 在传输层,创建了一个
org.omg.CORBA.portable.ApplicationException
,它已经失去了除该类以外的所有异常的详细信息。 内
com.sun.jts.CosTransactions.TopCoordinator.get_txcontext()
,交易屁股的状态回滚导致org.omg.CosTransactions.Unavailable
被抛出,其中被包裹和周围几次通过并最终导致这个错误显示给用户:org.omg.CORBA.INVALID_TRANSACTION: vmcid: 0x0 minor code: 0 completed: No at com.sun.jts.CosTransactions.CurrentTransaction.sendingRequest(CurrentTransaction.java:807) at com.sun.jts.CosTransactions.SenderReceiver.sending_request(SenderReceiver.java:139) at com.sun.jts.pi.InterceptorImpl.send_request(InterceptorImpl.java:344) at com.sun.corba.ee.impl.interceptors.InterceptorInvoker.invokeClientInterceptorStartingPoint(InterceptorInvoker.java:271) at com.sun.corba.ee.impl.interceptors.PIHandlerImpl.invokeClientPIStartingPoint(PIHandlerImpl.java:348) at com.sun.corba.ee.impl.protocol.CorbaClientRequestDispatcherImpl.beginRequest(CorbaClientRequestDispatcherImpl.java:284) at com.sun.corba.ee.impl.protocol.CorbaClientDelegateImpl.request(CorbaClientDelegateImpl.java:184) at com.sun.corba.ee.impl.presentation.rmi.StubInvocationHandlerImpl.privateInvoke(StubInvocationHandlerImpl.java:186) at com.sun.corba.ee.impl.presentation.rmi.StubInvocationHandlerImpl.invoke(StubInvocationHandlerImpl.java:152) at com.sun.corba.ee.impl.presentation.rmi.bcel.BCELStubBase.invoke(BCELStubBase.java:225)
有什么我可以在这里做的,以保存有关问题的实际原因的信息?