mirror of https://github.com/apache/activemq.git
r236@34: chirino | 2007-02-23 14:48:10 -0500
Flag a ConnectionContext as being a network connection if it sends us a BrokerInfo. Disable flow control if the producer is on a network connection.. trying to get around a network deadlock. git-svn-id: https://svn.apache.org/repos/asf/activemq/branches/activemq-4.1@511080 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
81ce0d1b4f
commit
579bc65ae3
|
@ -55,6 +55,7 @@ public class ConnectionContext {
|
||||||
private MessageAuthorizationPolicy messageAuthorizationPolicy;
|
private MessageAuthorizationPolicy messageAuthorizationPolicy;
|
||||||
private AtomicInteger referenceCounter = new AtomicInteger();
|
private AtomicInteger referenceCounter = new AtomicInteger();
|
||||||
private boolean dontSendReponse;
|
private boolean dontSendReponse;
|
||||||
|
private boolean networkConnection;
|
||||||
|
|
||||||
private final MessageEvaluationContext messageEvaluationContext = new MessageEvaluationContext();
|
private final MessageEvaluationContext messageEvaluationContext = new MessageEvaluationContext();
|
||||||
|
|
||||||
|
@ -255,4 +256,12 @@ public class ConnectionContext {
|
||||||
this.dontSendReponse = dontSendReponse;
|
this.dontSendReponse = dontSendReponse;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public synchronized boolean isNetworkConnection() {
|
||||||
|
return networkConnection;
|
||||||
|
}
|
||||||
|
|
||||||
|
public synchronized void setNetworkConnection(boolean networkConnection) {
|
||||||
|
this.networkConnection = networkConnection;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -125,6 +125,7 @@ public class TransportConnection implements Service, Connection, Task, CommandVi
|
||||||
private CountDownLatch stopLatch = new CountDownLatch(1);
|
private CountDownLatch stopLatch = new CountDownLatch(1);
|
||||||
protected final AtomicBoolean asyncException = new AtomicBoolean(false);
|
protected final AtomicBoolean asyncException = new AtomicBoolean(false);
|
||||||
private ConnectionContext context;
|
private ConnectionContext context;
|
||||||
|
private boolean networkConnection;
|
||||||
|
|
||||||
static class ConnectionState extends org.apache.activemq.state.ConnectionState {
|
static class ConnectionState extends org.apache.activemq.state.ConnectionState {
|
||||||
private final ConnectionContext context;
|
private final ConnectionContext context;
|
||||||
|
@ -693,6 +694,7 @@ public class TransportConnection implements Service, Connection, Task, CommandVi
|
||||||
context.setUserName(info.getUserName());
|
context.setUserName(info.getUserName());
|
||||||
context.setConnectionId(info.getConnectionId());
|
context.setConnectionId(info.getConnectionId());
|
||||||
context.setWireFormatInfo(wireFormatInfo);
|
context.setWireFormatInfo(wireFormatInfo);
|
||||||
|
context.setNetworkConnection(networkConnection);
|
||||||
context.incrementReference();
|
context.incrementReference();
|
||||||
this.manageable = info.isManageable();
|
this.manageable = info.isManageable();
|
||||||
|
|
||||||
|
@ -1058,6 +1060,12 @@ public class TransportConnection implements Service, Connection, Task, CommandVi
|
||||||
|
|
||||||
this.brokerInfo = info;
|
this.brokerInfo = info;
|
||||||
broker.addBroker(this, info);
|
broker.addBroker(this, info);
|
||||||
|
networkConnection = true;
|
||||||
|
for (Iterator iter = localConnectionStates.values().iterator(); iter.hasNext();) {
|
||||||
|
ConnectionState cs = (ConnectionState) iter.next();
|
||||||
|
cs.getContext().setNetworkConnection(true);
|
||||||
|
}
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -280,7 +280,7 @@ public class Queue implements Destination {
|
||||||
|
|
||||||
public void send(final ConnectionContext context, final Message message) throws Exception {
|
public void send(final ConnectionContext context, final Message message) throws Exception {
|
||||||
|
|
||||||
if (context.isProducerFlowControl()) {
|
if (context.isProducerFlowControl() && !context.isNetworkConnection()) {
|
||||||
if( message.isResponseRequired() ) {
|
if( message.isResponseRequired() ) {
|
||||||
if( usageManager.isFull() ) {
|
if( usageManager.isFull() ) {
|
||||||
// System.out.println("Registering callback...");
|
// System.out.println("Registering callback...");
|
||||||
|
|
|
@ -232,7 +232,7 @@ public class Topic implements Destination {
|
||||||
|
|
||||||
public void send(final ConnectionContext context, final Message message) throws Exception {
|
public void send(final ConnectionContext context, final Message message) throws Exception {
|
||||||
|
|
||||||
if (context.isProducerFlowControl()) {
|
if (context.isProducerFlowControl() && !context.isNetworkConnection() ) {
|
||||||
if (usageManager.isSendFailIfNoSpace() && usageManager.isFull()) {
|
if (usageManager.isSendFailIfNoSpace() && usageManager.isFull()) {
|
||||||
throw new javax.jms.ResourceAllocationException("Usage Manager memory limit reached");
|
throw new javax.jms.ResourceAllocationException("Usage Manager memory limit reached");
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -56,9 +56,13 @@ public class NetworkBridgeFilter implements DataStructure, BooleanExpression {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public boolean matches(MessageEvaluationContext message) throws JMSException{
|
public boolean matches(MessageEvaluationContext mec) throws JMSException{
|
||||||
try{
|
try{
|
||||||
return matchesForwardingFilter(message.getMessage());
|
//for Queues - the message can be acknowledged and dropped whilst still
|
||||||
|
//in the dispatch loop
|
||||||
|
//so need to get the reference to it
|
||||||
|
Message message = mec.getMessage();
|
||||||
|
return message != null && matchesForwardingFilter(message);
|
||||||
}catch(IOException e){
|
}catch(IOException e){
|
||||||
throw JMSExceptionSupport.create(e);
|
throw JMSExceptionSupport.create(e);
|
||||||
}
|
}
|
||||||
|
@ -132,4 +136,4 @@ public class NetworkBridgeFilter implements DataStructure, BooleanExpression {
|
||||||
this.networkBrokerId = remoteBrokerPath;
|
this.networkBrokerId = remoteBrokerPath;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue