mirror of https://github.com/apache/activemq.git
Recovery dispatch refactoring as the part of the solution for the https://issues.apache.org/activemq/browse/AMQ-2016
git-svn-id: https://svn.apache.org/repos/asf/activemq/trunk@736720 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
ab438f68c1
commit
807f64591d
|
@ -233,16 +233,18 @@ public class Queue extends BaseDestination implements Task {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// any newly paged in messages that are not dispatched are added to pagedInPending in iterate()
|
// do recovery dispatch only if it is a browser subscription
|
||||||
doPageIn(false);
|
if(sub instanceof QueueBrowserSubscription ) {
|
||||||
|
// any newly paged in messages that are not dispatched are added to pagedInPending in iterate()
|
||||||
|
doPageIn(false);
|
||||||
|
|
||||||
|
synchronized (pagedInMessages) {
|
||||||
|
RecoveryDispatch rd = new RecoveryDispatch();
|
||||||
|
rd.messages = new ArrayList<QueueMessageReference>(pagedInMessages.values());
|
||||||
|
rd.subscription = sub;
|
||||||
|
recoveries.addLast(rd);
|
||||||
|
}
|
||||||
|
|
||||||
synchronized (pagedInMessages) {
|
|
||||||
RecoveryDispatch rd = new RecoveryDispatch();
|
|
||||||
rd.messages = new ArrayList<QueueMessageReference>(pagedInMessages.values());
|
|
||||||
rd.subscription = sub;
|
|
||||||
recoveries.addLast(rd);
|
|
||||||
}
|
|
||||||
if( sub instanceof QueueBrowserSubscription ) {
|
|
||||||
((QueueBrowserSubscription)sub).incrementQueueRef();
|
((QueueBrowserSubscription)sub).incrementQueueRef();
|
||||||
}
|
}
|
||||||
if (!(this.optimizedDispatch || isSlave())) {
|
if (!(this.optimizedDispatch || isSlave())) {
|
||||||
|
@ -303,9 +305,14 @@ public class Queue extends BaseDestination implements Task {
|
||||||
doDispatch(list);
|
doDispatch(list);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
//if it is a last consumer (and not a browser) dispatch all pagedIn messages
|
||||||
if (consumers.isEmpty()) {
|
if (consumers.isEmpty() && !(sub instanceof QueueBrowserSubscription)) {
|
||||||
messages.gc();
|
List<QueueMessageReference> list = new ArrayList<QueueMessageReference>();
|
||||||
|
for (QueueMessageReference ref : pagedInMessages.values()) {
|
||||||
|
list.add(ref);
|
||||||
|
}
|
||||||
|
pagedInPendingDispatch.clear();
|
||||||
|
doDispatch(list);
|
||||||
}
|
}
|
||||||
if (!(this.optimizedDispatch || isSlave())) {
|
if (!(this.optimizedDispatch || isSlave())) {
|
||||||
wakeup();
|
wakeup();
|
||||||
|
@ -615,6 +622,7 @@ public class Queue extends BaseDestination implements Task {
|
||||||
int count = 0;
|
int count = 0;
|
||||||
List<Message> l = new ArrayList<Message>();
|
List<Message> l = new ArrayList<Message>();
|
||||||
try {
|
try {
|
||||||
|
pageInMessages(false);
|
||||||
synchronized (this.pagedInPendingDispatch) {
|
synchronized (this.pagedInPendingDispatch) {
|
||||||
for (Iterator<QueueMessageReference> i = this.pagedInPendingDispatch
|
for (Iterator<QueueMessageReference> i = this.pagedInPendingDispatch
|
||||||
.iterator(); i.hasNext()
|
.iterator(); i.hasNext()
|
||||||
|
@ -657,7 +665,7 @@ public class Queue extends BaseDestination implements Task {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch (IOException e) {
|
} catch (Exception e) {
|
||||||
LOG.error("Problem retrieving message in browse() ", e);
|
LOG.error("Problem retrieving message in browse() ", e);
|
||||||
}
|
}
|
||||||
return l.toArray(new Message[l.size()]);
|
return l.toArray(new Message[l.size()]);
|
||||||
|
@ -899,7 +907,7 @@ public class Queue extends BaseDestination implements Task {
|
||||||
int movedCounter = 0;
|
int movedCounter = 0;
|
||||||
Set<MessageReference> set = new CopyOnWriteArraySet<MessageReference>();
|
Set<MessageReference> set = new CopyOnWriteArraySet<MessageReference>();
|
||||||
do {
|
do {
|
||||||
pageInMessages();
|
doPageIn(true);
|
||||||
synchronized (pagedInMessages) {
|
synchronized (pagedInMessages) {
|
||||||
set.addAll(pagedInMessages.values());
|
set.addAll(pagedInMessages.values());
|
||||||
}
|
}
|
||||||
|
@ -981,7 +989,7 @@ public class Queue extends BaseDestination implements Task {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
boolean pageInMoreMessages = false;
|
boolean pageInMoreMessages = false;
|
||||||
synchronized (messages) {
|
synchronized (messages) {
|
||||||
pageInMoreMessages = !messages.isEmpty();
|
pageInMoreMessages = !messages.isEmpty();
|
||||||
|
@ -1230,6 +1238,7 @@ public class Queue extends BaseDestination implements Task {
|
||||||
pagedInPendingDispatch.add(qmr);
|
pagedInPendingDispatch.add(qmr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
wakeup();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1268,11 +1277,16 @@ public class Queue extends BaseDestination implements Task {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
interestCount++;
|
interestCount++;
|
||||||
|
} else {
|
||||||
|
// makes sure it gets dispatched again
|
||||||
|
if (!node.isDropped() && !((QueueMessageReference)node).isAcked() && (!node.isDropped() || s.getConsumerInfo().isBrowser())) {
|
||||||
|
interestCount++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (target == null && interestCount>0) {
|
if ((target == null && interestCount>0) || consumers.size() == 0) {
|
||||||
// This means all subs were full...
|
// This means all subs were full or that there are no consumers...
|
||||||
rc.add((QueueMessageReference)node);
|
rc.add((QueueMessageReference)node);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1288,10 +1302,6 @@ public class Queue extends BaseDestination implements Task {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//LOG.info(getName()+" Pending messages:");
|
|
||||||
//for (MessageReference n : rc) {
|
|
||||||
// LOG.info(getName()+" - " + n.getMessageId());
|
|
||||||
// }
|
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
|
@ -70,7 +70,7 @@ public class QueueDispatchSelector extends SimpleDispatchSelector {
|
||||||
if (result) {
|
if (result) {
|
||||||
result = exclusiveConsumer == null
|
result = exclusiveConsumer == null
|
||||||
|| exclusiveConsumer == subscription;
|
|| exclusiveConsumer == subscription;
|
||||||
if (result) {
|
if (result && !subscription.isFull()) {
|
||||||
QueueMessageReference node = (QueueMessageReference) m;
|
QueueMessageReference node = (QueueMessageReference) m;
|
||||||
// Keep message groups together.
|
// Keep message groups together.
|
||||||
String groupId = node.getGroupID();
|
String groupId = node.getGroupID();
|
||||||
|
|
Loading…
Reference in New Issue