From 47b809768ae8a2061be2e4f420ec8a8dc56ceb89 Mon Sep 17 00:00:00 2001 From: Bryan Burkholder Date: Mon, 12 Feb 2024 15:53:33 -0700 Subject: [PATCH] Refactor read only chunk timeout --- .../slack/kaldb/chunk/ReadOnlyChunkImpl.java | 29 +++++-------------- .../search/SearchResultUtilsTest.java | 10 +++++++ 2 files changed, 17 insertions(+), 22 deletions(-) diff --git a/kaldb/src/main/java/com/slack/kaldb/chunk/ReadOnlyChunkImpl.java b/kaldb/src/main/java/com/slack/kaldb/chunk/ReadOnlyChunkImpl.java index ed3ad5c54d..b220c2304b 100644 --- a/kaldb/src/main/java/com/slack/kaldb/chunk/ReadOnlyChunkImpl.java +++ b/kaldb/src/main/java/com/slack/kaldb/chunk/ReadOnlyChunkImpl.java @@ -1,5 +1,7 @@ package com.slack.kaldb.chunk; +import static com.slack.kaldb.server.KaldbConfig.DEFAULT_ZK_TIMEOUT_SECS; + import com.google.common.annotations.VisibleForTesting; import com.slack.kaldb.blobfs.BlobFs; import com.slack.kaldb.logstore.search.LogIndexSearcher; @@ -48,10 +50,6 @@ public class ReadOnlyChunkImpl implements Chunk { private static final Logger LOG = LoggerFactory.getLogger(ReadOnlyChunkImpl.class); - - @Deprecated // replace with sync methods, which use DEFAULT_ZK_TIMEOUT_SECS where possible - private static final int TIMEOUT_MS = 5000; - private ChunkInfo chunkInfo; private LogIndexSearcher logSearcher; private SearchMetadata searchMetadata; @@ -174,20 +172,14 @@ public static SearchMetadata registerSearchMetadata( snapshotName, cacheSearchContext.hostname), snapshotName, cacheSearchContext.toUrl()); - searchMetadataStore - .createAsync(metadata) - .toCompletableFuture() - .get(TIMEOUT_MS, TimeUnit.MILLISECONDS); + searchMetadataStore.createSync(metadata); return metadata; } private void unregisterSearchMetadata() throws ExecutionException, InterruptedException, TimeoutException { if (this.searchMetadata != null) { - searchMetadataStore - .deleteAsync(searchMetadata) - .toCompletableFuture() - .get(TIMEOUT_MS, TimeUnit.MILLISECONDS); + searchMetadataStore.deleteSync(searchMetadata); } } @@ -265,15 +257,8 @@ private void handleChunkAssignment(CacheSlotMetadata cacheSlotMetadata) { private SnapshotMetadata getSnapshotMetadata(String replicaId) throws ExecutionException, InterruptedException, TimeoutException { - ReplicaMetadata replicaMetadata = - replicaMetadataStore - .findAsync(replicaId) - .toCompletableFuture() - .get(TIMEOUT_MS, TimeUnit.MILLISECONDS); - return snapshotMetadataStore - .findAsync(replicaMetadata.snapshotId) - .toCompletableFuture() - .get(TIMEOUT_MS, TimeUnit.MILLISECONDS); + ReplicaMetadata replicaMetadata = replicaMetadataStore.findSync(replicaId); + return snapshotMetadataStore.findSync(replicaMetadata.snapshotId); } // We lock access when manipulating the chunk, as the close() @@ -319,7 +304,7 @@ private boolean setChunkMetadataState( try { cacheSlotMetadataStore .updateNonFreeCacheSlotState(cacheSlotMetadata, newState) - .get(TIMEOUT_MS, TimeUnit.MILLISECONDS); + .get(DEFAULT_ZK_TIMEOUT_SECS, TimeUnit.MILLISECONDS); return true; } catch (InterruptedException | ExecutionException | TimeoutException e) { LOG.error("Error setting chunk metadata state", e); diff --git a/kaldb/src/test/java/com/slack/kaldb/logstore/search/SearchResultUtilsTest.java b/kaldb/src/test/java/com/slack/kaldb/logstore/search/SearchResultUtilsTest.java index 90126ded85..f72a52233d 100644 --- a/kaldb/src/test/java/com/slack/kaldb/logstore/search/SearchResultUtilsTest.java +++ b/kaldb/src/test/java/com/slack/kaldb/logstore/search/SearchResultUtilsTest.java @@ -404,6 +404,16 @@ public void shouldConvertSchemaDefinitionToFromProto() { KaldbSearch.SchemaDefinition.newBuilder() .setType(KaldbSearch.FieldType.INTEGER) .build()); + + assertThat( + SearchResultUtils.fromSchemaDefinitionProto( + KaldbSearch.SchemaDefinition.newBuilder() + .setType(KaldbSearch.FieldType.ID) + .build())) + .isEqualTo(FieldType.ID); + assertThat(SearchResultUtils.toSchemaDefinitionProto(FieldType.ID)) + .isEqualTo( + KaldbSearch.SchemaDefinition.newBuilder().setType(KaldbSearch.FieldType.ID).build()); } @Test