From 8f5b98d6df89c6a9608dabb4bc9a5b082d7cf0df Mon Sep 17 00:00:00 2001 From: Sachin Kale Date: Tue, 19 Sep 2023 22:05:58 +0530 Subject: [PATCH] Fix checksum conversion and success criteria Signed-off-by: Sachin Kale --- .../org/opensearch/index/store/Store.java | 35 +++++++++++++------ 1 file changed, 24 insertions(+), 11 deletions(-) diff --git a/server/src/main/java/org/opensearch/index/store/Store.java b/server/src/main/java/org/opensearch/index/store/Store.java index 48e1ab5998fb1..6c98e006967c2 100644 --- a/server/src/main/java/org/opensearch/index/store/Store.java +++ b/server/src/main/java/org/opensearch/index/store/Store.java @@ -116,6 +116,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; @@ -963,11 +964,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); @@ -983,24 +986,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 + } } } } @@ -1496,7 +1509,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) {