diff --git a/activemq-broker/src/main/java/org/apache/activemq/broker/TransportConnection.java b/activemq-broker/src/main/java/org/apache/activemq/broker/TransportConnection.java index a9d36b5da3..cbb6ffe40a 100755 --- a/activemq-broker/src/main/java/org/apache/activemq/broker/TransportConnection.java +++ b/activemq-broker/src/main/java/org/apache/activemq/broker/TransportConnection.java @@ -858,14 +858,17 @@ public class TransportConnection implements Connection, Task, CommandVisitor { } } // Cascade the connection stop to temp destinations. - for (Iterator iter = cs.getTempDestinations().iterator(); iter.hasNext(); ) { - DestinationInfo di = iter.next(); - try { - broker.removeDestination(cs.getContext(), di.getDestination(), 0); - } catch (Throwable e) { - SERVICELOG.warn("Failed to remove tmp destination {}", di.getDestination(), e); + List tempDestinations = cs.getTempDestinations(); + synchronized (tempDestinations) { + for (Iterator iter = tempDestinations.iterator(); iter.hasNext(); ) { + DestinationInfo di = iter.next(); + try { + broker.removeDestination(cs.getContext(), di.getDestination(), 0); + } catch (Throwable e) { + SERVICELOG.warn("Failed to remove tmp destination {}", di.getDestination(), e); + } + iter.remove(); } - iter.remove(); } try { broker.removeConnection(cs.getContext(), cs.getInfo(), transportException.get());