mirror of https://github.com/apache/lucene.git
LUCENE_6119: disable merge throttling on close
git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1649755 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
cc3e6d9f93
commit
8ba1607af3
|
@ -89,6 +89,9 @@ public class ConcurrentMergeScheduler extends MergeScheduler {
|
||||||
/** Floor for IO write rate limit (we will never go any lower than this) */
|
/** Floor for IO write rate limit (we will never go any lower than this) */
|
||||||
private static final double MIN_MERGE_MB_PER_SEC = 5.0;
|
private static final double MIN_MERGE_MB_PER_SEC = 5.0;
|
||||||
|
|
||||||
|
/** Ceiling for IO write rate limit (we will never go any higher than this) */
|
||||||
|
private static final double MAX_MERGE_MB_PER_SEC = 10240.0;
|
||||||
|
|
||||||
/** Initial value for IO write rate limit when doAutoIOThrottle is true */
|
/** Initial value for IO write rate limit when doAutoIOThrottle is true */
|
||||||
private static final double START_MB_PER_SEC = 20.0;
|
private static final double START_MB_PER_SEC = 20.0;
|
||||||
|
|
||||||
|
@ -409,6 +412,12 @@ public class ConcurrentMergeScheduler extends MergeScheduler {
|
||||||
|
|
||||||
initDynamicDefaults(writer);
|
initDynamicDefaults(writer);
|
||||||
|
|
||||||
|
if (trigger == MergeTrigger.CLOSING) {
|
||||||
|
// Disable throttling on close:
|
||||||
|
targetMBPerSec = MAX_MERGE_MB_PER_SEC;
|
||||||
|
updateMergeThreads();
|
||||||
|
}
|
||||||
|
|
||||||
// First, quickly run through the newly proposed merges
|
// First, quickly run through the newly proposed merges
|
||||||
// and add any orthogonal merges (ie a merge not
|
// and add any orthogonal merges (ie a merge not
|
||||||
// involving segments already pending to be merged) to
|
// involving segments already pending to be merged) to
|
||||||
|
@ -681,8 +690,8 @@ public class ConcurrentMergeScheduler extends MergeScheduler {
|
||||||
if (newBacklog) {
|
if (newBacklog) {
|
||||||
// This new merge adds to the backlog: increase IO throttle by 20%
|
// This new merge adds to the backlog: increase IO throttle by 20%
|
||||||
targetMBPerSec *= 1.20;
|
targetMBPerSec *= 1.20;
|
||||||
if (targetMBPerSec > 10000) {
|
if (targetMBPerSec > MAX_MERGE_MB_PER_SEC) {
|
||||||
targetMBPerSec = 10000;
|
targetMBPerSec = MAX_MERGE_MB_PER_SEC;
|
||||||
}
|
}
|
||||||
if (verbose()) {
|
if (verbose()) {
|
||||||
if (curMBPerSec == targetMBPerSec) {
|
if (curMBPerSec == targetMBPerSec) {
|
||||||
|
|
Loading…
Reference in New Issue