mirror of https://github.com/apache/activemq.git
https://issues.apache.org/jira/browse/AMQ-5080 - revert short circut of recover when failover transport is not connected - using maxstartupMaxReconnectAttempts=x provides a better alternative. tm recovery need not start a managed connection or call getConnection before a call to xaresource.recover
This commit is contained in:
parent
66a689df0e
commit
207d4cdee6
|
@ -643,20 +643,11 @@ public class TransactionContext implements XAResource {
|
||||||
}
|
}
|
||||||
|
|
||||||
public Xid[] recover(int flag) throws XAException {
|
public Xid[] recover(int flag) throws XAException {
|
||||||
if (LOG.isDebugEnabled()) {
|
LOG.debug("recover({})", flag);
|
||||||
LOG.debug("Recover: " + flag);
|
|
||||||
}
|
|
||||||
|
|
||||||
TransactionInfo info = new TransactionInfo(getConnectionId(), null, TransactionInfo.RECOVER);
|
TransactionInfo info = new TransactionInfo(getConnectionId(), null, TransactionInfo.RECOVER);
|
||||||
try {
|
try {
|
||||||
this.connection.checkClosedOrFailed();
|
this.connection.checkClosedOrFailed();
|
||||||
final FailoverTransport failoverTransport = this.connection.getTransport().narrow(FailoverTransport.class);
|
|
||||||
if (failoverTransport != null && !failoverTransport.isConnected()) {
|
|
||||||
// otherwise call will block on reconnect forfeting any app level periodic check
|
|
||||||
XAException xaException = new XAException("Failover transport not connected: " + this.getConnection());
|
|
||||||
xaException.errorCode = XAException.XAER_RMERR;
|
|
||||||
throw xaException;
|
|
||||||
}
|
|
||||||
this.connection.ensureConnectionInfoSent();
|
this.connection.ensureConnectionInfoSent();
|
||||||
|
|
||||||
DataArrayResponse receipt = (DataArrayResponse)this.connection.syncSendPacket(info);
|
DataArrayResponse receipt = (DataArrayResponse)this.connection.syncSendPacket(info);
|
||||||
|
@ -668,7 +659,7 @@ public class TransactionContext implements XAResource {
|
||||||
answer = new XATransactionId[data.length];
|
answer = new XATransactionId[data.length];
|
||||||
System.arraycopy(data, 0, answer, 0, data.length);
|
System.arraycopy(data, 0, answer, 0, data.length);
|
||||||
}
|
}
|
||||||
LOG.trace("recover({})={}", flag, answer);
|
LOG.debug("recover({})={}", flag, answer);
|
||||||
return answer;
|
return answer;
|
||||||
} catch (JMSException e) {
|
} catch (JMSException e) {
|
||||||
throw toXAException(e);
|
throw toXAException(e);
|
||||||
|
|
Loading…
Reference in New Issue