mirror of https://github.com/apache/lucene.git
SOLR-13855: DistributedZkUpdateProcessor needs to propagate URP.finish()
Important since Run URP finish() propagates to updateLog to fsync()!
Closes #969
(cherry picked from commit 3ae8204248
)
This commit is contained in:
parent
6e6b36cbcd
commit
9a108996bb
|
@ -283,6 +283,10 @@ Bug Fixes
|
|||
|
||||
* SOLR-13677: All Metrics Gauges should be unregistered by components that registered them. (noble, ab)
|
||||
|
||||
* SOLR-13855: DistributedZkUpdateProcessor should have been propagating URP.finish() lifecycle like it used to before
|
||||
8.1 (a regression). Impacts integrity since Run URP's finish() propagates this to the updateLog to fsync.
|
||||
(David Smiley)
|
||||
|
||||
Other Changes
|
||||
----------------------
|
||||
|
||||
|
|
|
@ -1089,15 +1089,17 @@ public class DistributedUpdateProcessor extends UpdateRequestProcessor {
|
|||
}
|
||||
|
||||
@Override
|
||||
public void finish() throws IOException {
|
||||
assertNotFinished();
|
||||
public final void finish() throws IOException {
|
||||
assert ! finished : "lifecycle sanity check";
|
||||
finished = true;
|
||||
|
||||
doDistribFinish();
|
||||
|
||||
super.finish();
|
||||
}
|
||||
|
||||
protected void assertNotFinished() {
|
||||
assert ! finished : "lifecycle sanity check";
|
||||
finished = true;
|
||||
protected void doDistribFinish() throws IOException {
|
||||
// no-op for derived classes to implement
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -1045,17 +1045,10 @@ public class DistributedZkUpdateProcessor extends DistributedUpdateProcessor {
|
|||
super.processRollback(cmd);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void finish() throws IOException {
|
||||
// TODO: optionally fail if n replicas are not reached...
|
||||
protected void doDistribFinish() {
|
||||
clusterState = zkController.getClusterState();
|
||||
|
||||
assertNotFinished();
|
||||
|
||||
doFinish();
|
||||
}
|
||||
|
||||
// TODO: optionally fail if n replicas are not reached...
|
||||
private void doFinish() {
|
||||
boolean shouldUpdateTerms = isLeader && isIndexChanged;
|
||||
if (shouldUpdateTerms) {
|
||||
ZkShardTerms zkShardTerms = zkController.getShardTerms(cloudDesc.getCollectionName(), cloudDesc.getShardId());
|
||||
|
@ -1195,6 +1188,7 @@ public class DistributedZkUpdateProcessor extends DistributedUpdateProcessor {
|
|||
if (0 < errorsForClient.size()) {
|
||||
throw new DistributedUpdatesAsyncException(errorsForClient);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
Loading…
Reference in New Issue