mirror of https://github.com/apache/lucene.git
LUCENE-4158: leave stall control on each wakeup call to prevent full flush starvation due to queued flushes
git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1353433 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
fcc0fea1f3
commit
7c26573fe3
|
@ -633,7 +633,13 @@ final class DocumentsWriterFlushControl {
|
||||||
* checked out DWPT are available
|
* checked out DWPT are available
|
||||||
*/
|
*/
|
||||||
void waitIfStalled() {
|
void waitIfStalled() {
|
||||||
stallControl.waitIfStalled();
|
if (documentsWriter.infoStream.isEnabled("DWFC")) {
|
||||||
|
documentsWriter.infoStream.message("DWFC",
|
||||||
|
"waitIfStalled: numFlushesPending: " + flushQueue.size()
|
||||||
|
+ " netBytes: " + netBytes() + " flushBytes: " + flushBytes()
|
||||||
|
+ " fullFlush: " + fullFlush);
|
||||||
|
}
|
||||||
|
stallControl.waitIfStalled();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -67,17 +67,16 @@ final class DocumentsWriterStallControl {
|
||||||
void waitIfStalled() {
|
void waitIfStalled() {
|
||||||
if (stalled) {
|
if (stalled) {
|
||||||
synchronized (this) {
|
synchronized (this) {
|
||||||
boolean hasWaited = false;
|
if (stalled) { // react on the first wakeup call!
|
||||||
while (stalled) {
|
// don't loop here, higher level logic will re-stall!
|
||||||
try {
|
try {
|
||||||
assert hasWaited || incWaiters();
|
assert incWaiters();
|
||||||
assert (hasWaited = true);
|
|
||||||
wait();
|
wait();
|
||||||
|
assert decrWaiters();
|
||||||
} catch (InterruptedException e) {
|
} catch (InterruptedException e) {
|
||||||
throw new ThreadInterruptedException(e);
|
throw new ThreadInterruptedException(e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
assert !hasWaited || decrWaiters();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -63,7 +63,6 @@ public class TestDocumentsWriterStallControl extends LuceneTestCase {
|
||||||
|
|
||||||
Thread[] stallThreads = new Thread[atLeast(3)];
|
Thread[] stallThreads = new Thread[atLeast(3)];
|
||||||
for (int i = 0; i < stallThreads.length; i++) {
|
for (int i = 0; i < stallThreads.length; i++) {
|
||||||
final int threadId = i;
|
|
||||||
final int stallProbability = 1 +random().nextInt(10);
|
final int stallProbability = 1 +random().nextInt(10);
|
||||||
stallThreads[i] = new Thread() {
|
stallThreads[i] = new Thread() {
|
||||||
public void run() {
|
public void run() {
|
||||||
|
|
Loading…
Reference in New Issue