Core: do not throttle recovery indexing operations when replaying transaction log
Closes #9396 Closes #9394
This commit is contained in:
parent
dfc2c9f3a1
commit
50e9108305
|
@ -339,9 +339,14 @@ public class InternalEngine implements Engine {
|
||||||
final IndexWriter writer;
|
final IndexWriter writer;
|
||||||
try (InternalLock _ = readLock.acquire()) {
|
try (InternalLock _ = readLock.acquire()) {
|
||||||
writer = currentIndexWriter();
|
writer = currentIndexWriter();
|
||||||
|
if (create.origin() == Operation.Origin.RECOVERY) {
|
||||||
|
// Don't throttle recovery operations
|
||||||
|
innerCreate(create, writer);
|
||||||
|
} else {
|
||||||
try (Releasable r = throttle.acquireThrottle()) {
|
try (Releasable r = throttle.acquireThrottle()) {
|
||||||
innerCreate(create, writer);
|
innerCreate(create, writer);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
dirty = true;
|
dirty = true;
|
||||||
flushNeeded = true;
|
flushNeeded = true;
|
||||||
} catch (OutOfMemoryError | IllegalStateException | IOException t) {
|
} catch (OutOfMemoryError | IllegalStateException | IOException t) {
|
||||||
|
@ -351,7 +356,6 @@ public class InternalEngine implements Engine {
|
||||||
checkVersionMapRefresh();
|
checkVersionMapRefresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void innerCreate(Create create, IndexWriter writer) throws IOException {
|
private void innerCreate(Create create, IndexWriter writer) throws IOException {
|
||||||
if (engineConfig.isOptimizeAutoGenerateId() && create.autoGeneratedId() && !create.canHaveDuplicates()) {
|
if (engineConfig.isOptimizeAutoGenerateId() && create.autoGeneratedId() && !create.canHaveDuplicates()) {
|
||||||
// We don't need to lock because this ID cannot be concurrently updated:
|
// We don't need to lock because this ID cannot be concurrently updated:
|
||||||
|
@ -443,9 +447,14 @@ public class InternalEngine implements Engine {
|
||||||
final IndexWriter writer;
|
final IndexWriter writer;
|
||||||
try (InternalLock _ = readLock.acquire()) {
|
try (InternalLock _ = readLock.acquire()) {
|
||||||
writer = currentIndexWriter();
|
writer = currentIndexWriter();
|
||||||
|
if (index.origin() == Operation.Origin.RECOVERY) {
|
||||||
|
// Don't throttle recovery operations
|
||||||
|
innerIndex(index, writer);
|
||||||
|
} else {
|
||||||
try (Releasable r = throttle.acquireThrottle()) {
|
try (Releasable r = throttle.acquireThrottle()) {
|
||||||
innerIndex(index, writer);
|
innerIndex(index, writer);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
dirty = true;
|
dirty = true;
|
||||||
flushNeeded = true;
|
flushNeeded = true;
|
||||||
} catch (OutOfMemoryError | IllegalStateException | IOException t) {
|
} catch (OutOfMemoryError | IllegalStateException | IOException t) {
|
||||||
|
|
Loading…
Reference in New Issue