mirror of https://github.com/apache/activemq.git
https://issues.apache.org/activemq/browse/AMQ-2448 - thread leak when network trying to connect to unavailable broker
git-svn-id: https://svn.apache.org/repos/asf/activemq/trunk@932403 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
05f82a9b6d
commit
80a7ec59b4
|
@ -530,9 +530,6 @@
|
|||
<!-- breaks hudson: disable till we get a chance to give it the time that it needs - http://hudson.zones.apache.org/hudson/job/ActiveMQ/org.apache.activemq$activemq-core/199/testReport/org.apache.activemq.network/BrokerNetworkWithStuckMessagesTest/testBrokerNetworkWithStuckMessages/ -->
|
||||
<exclude>**/BrokerNetworkWithStuckMessagesTest.*</exclude>
|
||||
|
||||
<!-- until https://issues.apache.org/activemq/browse/AMQ-2448 is fixed -->
|
||||
<exclude>**/VmTransportNetworkBrokerTest.*</exclude>
|
||||
|
||||
</excludes>
|
||||
</configuration>
|
||||
</plugin>
|
||||
|
|
|
@ -109,11 +109,15 @@ public class VMTransport implements Transport, Task {
|
|||
peer.enqueueValve.decrement();
|
||||
}
|
||||
|
||||
dispatch(peer, transportListener, command);
|
||||
}
|
||||
|
||||
public void dispatch(VMTransport transport, TransportListener transportListener, Object command) {
|
||||
if( transportListener!=null ) {
|
||||
if( command == DISCONNECT ) {
|
||||
transportListener.onException(new TransportDisposedIOException("Peer (" + peer.toString() + ") disposed."));
|
||||
} else {
|
||||
peer.receiveCounter++;
|
||||
transport.receiveCounter++;
|
||||
transportListener.onCommand(command);
|
||||
}
|
||||
}
|
||||
|
@ -129,7 +133,7 @@ public class VMTransport implements Transport, Task {
|
|||
Object command;
|
||||
while ((command = messageQueue.poll()) != null && !stopping.get() ) {
|
||||
receiveCounter++;
|
||||
transportListener.onCommand(command);
|
||||
dispatch(this, transportListener, command);
|
||||
}
|
||||
}
|
||||
started = true;
|
||||
|
@ -150,6 +154,13 @@ public class VMTransport implements Transport, Task {
|
|||
// If stop() is called while being start()ed.. then we can't stop until we return to the start() method.
|
||||
if( enqueueValve.isOn() ) {
|
||||
|
||||
// let the peer know that we are disconnecting..
|
||||
try {
|
||||
peer.transportListener.onException(new TransportDisposedIOException("Peer (" + peer.toString() + ") disposed."));
|
||||
} catch (Exception ignore) {
|
||||
}
|
||||
|
||||
|
||||
TaskRunner tr = null;
|
||||
try {
|
||||
enqueueValve.turnOff();
|
||||
|
@ -168,12 +179,10 @@ public class VMTransport implements Transport, Task {
|
|||
if (tr != null) {
|
||||
tr.shutdown(1000);
|
||||
}
|
||||
// let the peer know that we are disconnecting..
|
||||
try {
|
||||
oneway(DISCONNECT);
|
||||
} catch (Exception ignore) {
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -206,16 +206,7 @@ public class VMTransportFactory extends TransportFactory {
|
|||
|
||||
public static void stopped(VMTransportServer server) {
|
||||
String host = server.getBindURI().getHost();
|
||||
SERVERS.remove(host);
|
||||
TransportConnector connector = CONNECTORS.remove(host);
|
||||
if (connector != null) {
|
||||
LOG.debug("Shutting down VM connectors for broker: " + host);
|
||||
ServiceSupport.dispose(connector);
|
||||
BrokerService broker = BROKERS.remove(host);
|
||||
if (broker != null) {
|
||||
ServiceSupport.dispose(broker);
|
||||
}
|
||||
}
|
||||
stopped(host);
|
||||
}
|
||||
|
||||
public static void stopped(String host) {
|
||||
|
|
|
@ -60,6 +60,5 @@
|
|||
<property name="password" value="${activemq.password}"/>
|
||||
</bean>
|
||||
</property>
|
||||
<property name="useSingleConnection" value="true" />
|
||||
</bean>
|
||||
</beans>
|
||||
|
|
|
@ -58,6 +58,5 @@
|
|||
<property name="password" value="${activemq.password}"/>
|
||||
</bean>
|
||||
</property>
|
||||
<property name="useSingleConnection" value="true" />
|
||||
</bean>
|
||||
</beans>
|
||||
|
|
Loading…
Reference in New Issue