关于Weblogic中XAER_NOTA XAException的两种解释
2009-09-22 00:00:00 来源:WEB开发网2:如果基于业务需要,我们需要额外配置两个XA Datasource,分别指向 XAPool_A、XAPool_B,如下:
XADatasource_12----〉XAPool_A
XADatasource_22----〉XAPool_B
部署Datasource的时候,Weblogic会判断这个Datasource是不是XA类型的,如果是XA类型的Datasource,我们需要将这个datasource实例注册到Process- wide的resourceDescriptorList中,如下:
registerResource(poolName, (XAResource)driverInstance, registrationProperties);
在register前,我们先调用unregisterResource(poolName)将该poolName 对应的resource从 resourceDescriptorList中unregister掉。这样 XADatasource_12、XADatasource_22部署后,我们可以看到process-wide的 resourceDescriptorList中的对象变化:
部署前:XADatasource_11, XADatasource_21
部署后:XADatasource_12, XADatasource_22
注意:如果XADatasource11、12, XADatasource_21、22不存在多数据源 指向同连接池的话,部署后,四个Datasource应该都出现在 resourceDescriptorList中。
3:如果我们此时执行xaTest()测试代码,过程如下:
3.1:Connection conn1 = getConnection("t3://localhost:7011", XADatasource_11);
在getConnection()的时候, weblogic中需要将 XAResource enlist到当前的transaction中,如下:
Thread [ExecuteThread: '14' for queue: 'weblogic.kernel.Default'] (Suspended)
ServerTransactionImpl.enlistResource(XAResource) line: 412
DataSource.enlist(Transaction) line: 1519
DataSource.refreshXAConnAndEnlist(XAConnection, JTAConnection, boolean) line: 1459
DataSource.getConnection() line: 452
DataSource.connect(String, Properties) line: 410
RmiDataSource.getConnection() line: 329
RmiDataSource_WLSkel.invoke(int, InboundRequest, OutboundResponse, Object) line: not available
ClusterableServerRef(BasicServerRef).invoke(RuntimeMethodDescriptor, InboundRequest, OutboundResponse) line: 492
ClusterableServerRef(ReplicaAwareServerRef).invoke(RuntimeMethodDescriptor, InboundRequest, OutboundResponse) line: 108
BasicServerRef$1.run() line: 435
AuthenticatedSubject.doAs(AbstractSubject, PrivilegedExceptionAction) line: 363
SecurityManager.runAs(AuthenticatedSubject, AuthenticatedSubject, PrivilegedExceptionAction) line: 147
ClusterableServerRef(BasicServerRef).handleRequest(InboundRequest) line: 430
BasicExecuteRequest.execute(ExecuteThread) line: 35
ExecuteThread.execute(ExecuteRequest) line: 224
ExecuteThread.run() line: 183
更多精彩
赞助商链接