Skip to content

Commit

Permalink
Fix checksum conversion and success criteria
Browse files Browse the repository at this point in the history
Signed-off-by: Sachin Kale <[email protected]>
  • Loading branch information
Sachin Kale committed Oct 4, 2023
1 parent 326ecec commit 05b3ed7
Showing 1 changed file with 24 additions and 11 deletions.
35 changes: 24 additions & 11 deletions server/src/main/java/org/opensearch/index/store/Store.java
Original file line number Diff line number Diff line change
Expand Up @@ -118,6 +118,7 @@
import java.util.concurrent.locks.ReentrantReadWriteLock;
import java.util.function.Consumer;

import static java.lang.Character.MAX_RADIX;
import static java.util.Collections.emptyMap;
import static java.util.Collections.unmodifiableMap;
import static org.opensearch.index.seqno.SequenceNumbers.LOCAL_CHECKPOINT_KEY;
Expand Down Expand Up @@ -979,11 +980,13 @@ public void copyFrom(Directory from, String src, String dest, IOContext context)
beforeDownload(fileSize);
boolean success = false;
long startTime = System.currentTimeMillis();
try (IndexInput is = from.openInput(src, context); IndexOutput os = createOutput(dest, context)) {
try {
if (from instanceof RemoteSegmentStoreDirectory) {
copyFileAndValidateChecksum(from, is, os, dest, fileSize);
try (IndexInput is = from.openInput(src, context); IndexOutput os = createOutput(dest, context)) {
copyFileAndValidateChecksum(from, is, os, dest, fileSize);
}
} else {
os.copyBytes(is, is.length());
super.copyFrom(from, src, dest, context);
}
success = true;
afterDownload(fileSize, startTime);
Expand All @@ -999,24 +1002,34 @@ private void copyFileAndValidateChecksum(Directory from, IndexInput is, IndexOut
RemoteSegmentStoreDirectory.UploadedSegmentMetadata metadata = ((RemoteSegmentStoreDirectory) from)
.getSegmentsUploadedToRemoteStore()
.get(dest);
boolean success = false;
try {
// Here, we don't need the exact version as LuceneVerifyingIndexOutput does not verify version
// It is just used to emit logs when the entire metadata object is provided as parameter. Also,
// we can't provide null version as StoreFileMetadata has non-null check on writtenBy field.
Version luceneMajorVersion = Version.parse(metadata.getWrittenByMajor() + ".0.0");
StoreFileMetadata storeFileMetadata = new StoreFileMetadata(dest, fileSize, metadata.getChecksum(), luceneMajorVersion);
Long checksum = Long.parseLong(metadata.getChecksum());
StoreFileMetadata storeFileMetadata = new StoreFileMetadata(
dest,
fileSize,
Long.toString(checksum, MAX_RADIX),
luceneMajorVersion
);
VerifyingIndexOutput verifyingIndexOutput = new LuceneVerifyingIndexOutput(storeFileMetadata, os);
verifyingIndexOutput.copyBytes(is, is.length());
verifyingIndexOutput.verify();
success = true;
} catch (ParseException e) {
throw new IOException("Exception while reading version info for segment file from remote store: " + dest, e);
} finally {
// If the exception is thrown after file is created, we clean up the file.
// We ignore the exception as the deletion is best-effort basis and can fail if file does not exist.
try {
deleteFile("Quietly deleting", dest);
} catch (Exception e) {
// Ignore
if (success == false) {
// If the exception is thrown after file is created, we clean up the file.
// We ignore the exception as the deletion is best-effort basis and can fail if file does not exist.
try {
deleteFile("Quietly deleting", dest);
} catch (Exception e) {
// Ignore
}
}
}
}
Expand Down Expand Up @@ -1512,7 +1525,7 @@ public static boolean isAutogenerated(String name) {
* Produces a string representation of the given digest value.
*/
public static String digestToString(long digest) {
return Long.toString(digest, Character.MAX_RADIX);
return Long.toString(digest, MAX_RADIX);
}

public void deleteQuiet(String... files) {
Expand Down

0 comments on commit 05b3ed7

Please sign in to comment.