Remove "force" version type (#47228)
It's been deprecated long ago and can be removed. Relates to #20377 Closes #19769
This commit is contained in:
parent
b270f70be1
commit
9dc90e41fc
|
@ -191,8 +191,6 @@ final class RequestConverters {
|
||||||
metadata.field("version_type", "external");
|
metadata.field("version_type", "external");
|
||||||
} else if (versionType == VersionType.EXTERNAL_GTE) {
|
} else if (versionType == VersionType.EXTERNAL_GTE) {
|
||||||
metadata.field("version_type", "external_gte");
|
metadata.field("version_type", "external_gte");
|
||||||
} else if (versionType == VersionType.FORCE) {
|
|
||||||
metadata.field("version_type", "force");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -131,9 +131,7 @@ better GET scaling we will have.
|
||||||
===== Versioning support
|
===== Versioning support
|
||||||
|
|
||||||
You can use the `version` parameter to retrieve the document only if
|
You can use the `version` parameter to retrieve the document only if
|
||||||
its current version is equal to the specified one. This behavior is the same
|
its current version is equal to the specified one.
|
||||||
for all version types with the exception of version type `FORCE` which always
|
|
||||||
retrieves the document. Note that `FORCE` version type is deprecated.
|
|
||||||
|
|
||||||
Internally, Elasticsearch has marked the old document as deleted and added an
|
Internally, Elasticsearch has marked the old document as deleted and added an
|
||||||
entirely new document. The old version of the document doesn’t disappear
|
entirely new document. The old version of the document doesn’t disappear
|
||||||
|
|
|
@ -72,8 +72,7 @@ public interface DocWriteRequest<T> extends IndicesRequest {
|
||||||
* @return the Request
|
* @return the Request
|
||||||
*/
|
*/
|
||||||
T defaultTypeIfNull(String defaultType);
|
T defaultTypeIfNull(String defaultType);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the id of the document for this request
|
* Get the id of the document for this request
|
||||||
* @return the id
|
* @return the id
|
||||||
|
@ -257,9 +256,6 @@ public interface DocWriteRequest<T> extends IndicesRequest {
|
||||||
validationException = addValidationError("illegal version value [" + version + "] for version type ["
|
validationException = addValidationError("illegal version value [" + version + "] for version type ["
|
||||||
+ versionType.name() + "]", validationException);
|
+ versionType.name() + "]", validationException);
|
||||||
}
|
}
|
||||||
if (versionType == VersionType.FORCE) {
|
|
||||||
validationException = addValidationError("version type [force] may no longer be used", validationException);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (versionType == VersionType.INTERNAL && version != Versions.MATCH_ANY && version != Versions.MATCH_DELETED) {
|
if (versionType == VersionType.INTERNAL && version != Versions.MATCH_ANY && version != Versions.MATCH_DELETED) {
|
||||||
validationException = addValidationError("internal versioning can not be used for optimistic concurrency control. " +
|
validationException = addValidationError("internal versioning can not be used for optimistic concurrency control. " +
|
||||||
|
|
|
@ -136,9 +136,6 @@ public class GetRequest extends SingleShardRequest<GetRequest> implements Realti
|
||||||
validationException = ValidateActions.addValidationError("illegal version value [" + version + "] for version type ["
|
validationException = ValidateActions.addValidationError("illegal version value [" + version + "] for version type ["
|
||||||
+ versionType.name() + "]", validationException);
|
+ versionType.name() + "]", validationException);
|
||||||
}
|
}
|
||||||
if (versionType == VersionType.FORCE) {
|
|
||||||
validationException = ValidateActions.addValidationError("version type [force] may no longer be used", validationException);
|
|
||||||
}
|
|
||||||
return validationException;
|
return validationException;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -201,55 +201,6 @@ public enum VersionType implements Writeable {
|
||||||
return version >= 0L || version == Versions.MATCH_ANY;
|
return version >= 0L || version == Versions.MATCH_ANY;
|
||||||
}
|
}
|
||||||
|
|
||||||
},
|
|
||||||
/**
|
|
||||||
* Warning: this version type should be used with care. Concurrent indexing may result in loss of data on replicas
|
|
||||||
*
|
|
||||||
* @deprecated this will be removed in 7.0 and should not be used! It is *ONLY* for backward compatibility with 5.0 indices
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
FORCE((byte) 3) {
|
|
||||||
@Override
|
|
||||||
public boolean isVersionConflictForWrites(long currentVersion, long expectedVersion, boolean deleted) {
|
|
||||||
if (currentVersion == Versions.NOT_FOUND) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (expectedVersion == Versions.MATCH_ANY) {
|
|
||||||
throw new IllegalStateException("you must specify a version when use VersionType.FORCE");
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String explainConflictForWrites(long currentVersion, long expectedVersion, boolean deleted) {
|
|
||||||
throw new AssertionError("VersionType.FORCE should never result in a write conflict");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean isVersionConflictForReads(long currentVersion, long expectedVersion) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String explainConflictForReads(long currentVersion, long expectedVersion) {
|
|
||||||
throw new AssertionError("VersionType.FORCE should never result in a read conflict");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public long updateVersion(long currentVersion, long expectedVersion) {
|
|
||||||
return expectedVersion;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean validateVersionForWrites(long version) {
|
|
||||||
return version >= 0L;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean validateVersionForReads(long version) {
|
|
||||||
return version >= 0L || version == Versions.MATCH_ANY;
|
|
||||||
}
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
private final byte value;
|
private final byte value;
|
||||||
|
@ -335,8 +286,6 @@ public enum VersionType implements Writeable {
|
||||||
return EXTERNAL;
|
return EXTERNAL;
|
||||||
} else if ("external_gte".equals(versionType)) {
|
} else if ("external_gte".equals(versionType)) {
|
||||||
return EXTERNAL_GTE;
|
return EXTERNAL_GTE;
|
||||||
} else if ("force".equals(versionType)) {
|
|
||||||
return FORCE;
|
|
||||||
}
|
}
|
||||||
throw new IllegalArgumentException("No version type match [" + versionType + "]");
|
throw new IllegalArgumentException("No version type match [" + versionType + "]");
|
||||||
}
|
}
|
||||||
|
@ -359,8 +308,6 @@ public enum VersionType implements Writeable {
|
||||||
return EXTERNAL;
|
return EXTERNAL;
|
||||||
} else if (value == 2) {
|
} else if (value == 2) {
|
||||||
return EXTERNAL_GTE;
|
return EXTERNAL_GTE;
|
||||||
} else if (value == 3) {
|
|
||||||
return FORCE;
|
|
||||||
}
|
}
|
||||||
throw new IllegalArgumentException("No version type match [" + value + "]");
|
throw new IllegalArgumentException("No version type match [" + value + "]");
|
||||||
}
|
}
|
||||||
|
|
|
@ -1805,7 +1805,7 @@ public class InternalEngineTests extends EngineTestCase {
|
||||||
|
|
||||||
public void testOutOfOrderDocsOnReplica() throws IOException {
|
public void testOutOfOrderDocsOnReplica() throws IOException {
|
||||||
final List<Engine.Operation> ops = generateSingleDocHistory(true,
|
final List<Engine.Operation> ops = generateSingleDocHistory(true,
|
||||||
randomFrom(VersionType.INTERNAL, VersionType.EXTERNAL, VersionType.EXTERNAL_GTE, VersionType.FORCE),
|
randomFrom(VersionType.INTERNAL, VersionType.EXTERNAL, VersionType.EXTERNAL_GTE),
|
||||||
2, 2, 20, "1");
|
2, 2, 20, "1");
|
||||||
assertOpsOnReplica(ops, replicaEngine, true, logger);
|
assertOpsOnReplica(ops, replicaEngine, true, logger);
|
||||||
}
|
}
|
||||||
|
|
|
@ -804,9 +804,6 @@ public abstract class EngineTestCase extends ESTestCase {
|
||||||
case EXTERNAL_GTE:
|
case EXTERNAL_GTE:
|
||||||
version = randomBoolean() ? Math.max(i - 1, 0) : i;
|
version = randomBoolean() ? Math.max(i - 1, 0) : i;
|
||||||
break;
|
break;
|
||||||
case FORCE:
|
|
||||||
version = randomNonNegativeLong();
|
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
throw new UnsupportedOperationException("unknown version type: " + versionType);
|
throw new UnsupportedOperationException("unknown version type: " + versionType);
|
||||||
}
|
}
|
||||||
|
|
|
@ -139,7 +139,7 @@ public class FollowingEngineTests extends ESTestCase {
|
||||||
final EngineConfig engineConfig = engineConfig(shardId, indexSettings, threadPool, store, logger, xContentRegistry());
|
final EngineConfig engineConfig = engineConfig(shardId, indexSettings, threadPool, store, logger, xContentRegistry());
|
||||||
try (FollowingEngine followingEngine = createEngine(store, engineConfig)) {
|
try (FollowingEngine followingEngine = createEngine(store, engineConfig)) {
|
||||||
final VersionType versionType =
|
final VersionType versionType =
|
||||||
randomFrom(VersionType.INTERNAL, VersionType.EXTERNAL, VersionType.EXTERNAL_GTE, VersionType.FORCE);
|
randomFrom(VersionType.INTERNAL, VersionType.EXTERNAL, VersionType.EXTERNAL_GTE);
|
||||||
final List<Engine.Operation> ops = EngineTestCase.generateSingleDocHistory(true, versionType, 2, 2, 20, "id");
|
final List<Engine.Operation> ops = EngineTestCase.generateSingleDocHistory(true, versionType, 2, 2, 20, "id");
|
||||||
ops.stream().mapToLong(op -> op.seqNo()).max().ifPresent(followingEngine::advanceMaxSeqNoOfUpdatesOrDeletes);
|
ops.stream().mapToLong(op -> op.seqNo()).max().ifPresent(followingEngine::advanceMaxSeqNoOfUpdatesOrDeletes);
|
||||||
EngineTestCase.assertOpsOnReplica(ops, followingEngine, true, logger);
|
EngineTestCase.assertOpsOnReplica(ops, followingEngine, true, logger);
|
||||||
|
|
Loading…
Reference in New Issue