summaryrefslogtreecommitdiff
path: root/qpid/java/broker-core
diff options
context:
space:
mode:
authorRobert Godfrey <rgodfrey@apache.org>2015-02-11 11:06:23 +0000
committerRobert Godfrey <rgodfrey@apache.org>2015-02-11 11:06:23 +0000
commit83393913d1a7c9bced3c6681423b55fe1d6717e9 (patch)
tree9b917b52420a38e251b7cef7521b3d0001c64ede /qpid/java/broker-core
parent35f8db0065335d4da24de4459cf228b077218138 (diff)
downloadqpid-python-83393913d1a7c9bced3c6681423b55fe1d6717e9.tar.gz
QPID-6383 : don't auto delete queues because the children are being removed due to broker closure
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk@1658923 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/java/broker-core')
-rw-r--r--qpid/java/broker-core/src/main/java/org/apache/qpid/server/queue/AbstractQueue.java14
1 files changed, 13 insertions, 1 deletions
diff --git a/qpid/java/broker-core/src/main/java/org/apache/qpid/server/queue/AbstractQueue.java b/qpid/java/broker-core/src/main/java/org/apache/qpid/server/queue/AbstractQueue.java
index f905558f13..8f4c3d6df0 100644
--- a/qpid/java/broker-core/src/main/java/org/apache/qpid/server/queue/AbstractQueue.java
+++ b/qpid/java/broker-core/src/main/java/org/apache/qpid/server/queue/AbstractQueue.java
@@ -245,6 +245,7 @@ public abstract class AbstractQueue<X extends AbstractQueue<X>>
private final ConcurrentLinkedQueue<EnqueueRequest> _postRecoveryQueue = new ConcurrentLinkedQueue<>();
private final QueueRunner _queueRunner = new QueueRunner(this);
+ private boolean _closing;
protected AbstractQueue(Map<String, Object> attributes, VirtualHostImpl virtualHost)
{
@@ -753,6 +754,15 @@ public abstract class AbstractQueue<X extends AbstractQueue<X>>
}
+ @Override
+ protected void beforeClose()
+ {
+ _closing = true;
+ super.beforeClose();
+ }
+
+
+
synchronized void unregisterConsumer(final QueueConsumerImpl consumer)
{
if (consumer == null)
@@ -793,7 +803,8 @@ public abstract class AbstractQueue<X extends AbstractQueue<X>>
if(!consumer.isTransient()
&& ( getLifetimePolicy() == LifetimePolicy.DELETE_ON_NO_OUTBOUND_LINKS
|| getLifetimePolicy() == LifetimePolicy.DELETE_ON_NO_LINKS )
- && getConsumerCount() == 0)
+ && getConsumerCount() == 0
+ && !(consumer.isDurable() && _closing))
{
if (_logger.isInfoEnabled())
@@ -1797,6 +1808,7 @@ public abstract class AbstractQueue<X extends AbstractQueue<X>>
{
ReferenceCountingExecutorService.getInstance().releaseExecutorService();
}
+ _closing = false;
}
public void checkCapacity(AMQSessionModel channel)