From 28925da9f7a83806854f4209b3e49ab3598aa809 Mon Sep 17 00:00:00 2001 From: Yu Ning <78631860+Chillax-0v0@users.noreply.github.com> Date: Mon, 5 Feb 2024 12:26:27 +0800 Subject: [PATCH] fix(s3stream): register metrics after starting the wal (#920) Signed-off-by: Ning Yu --- .../automq/stream/s3/wal/BlockWALService.java | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/s3stream/src/main/java/com/automq/stream/s3/wal/BlockWALService.java b/s3stream/src/main/java/com/automq/stream/s3/wal/BlockWALService.java index 52eaa8601..91490cfba 100644 --- a/s3stream/src/main/java/com/automq/stream/s3/wal/BlockWALService.java +++ b/s3stream/src/main/java/com/automq/stream/s3/wal/BlockWALService.java @@ -290,7 +290,11 @@ public WriteAheadLog start() throws IOException { walHeaderReady(header); started.set(true); + LOGGER.info("block WAL service started, cost: {} ms", stopWatch.getTime(TimeUnit.MILLISECONDS)); + return this; + } + private void registerMetrics() { S3StreamMetricsManager.registerDeltaWalOffsetSupplier(() -> { try { return this.getCurrentStartOffset(); @@ -299,9 +303,6 @@ public WriteAheadLog start() throws IOException { return 0L; } }, () -> walHeader.getFlushedTrimOffset()); - - LOGGER.info("block WAL service started, cost: {} ms", stopWatch.getTime(TimeUnit.MILLISECONDS)); - return this; } private long getCurrentStartOffset() { @@ -480,7 +481,14 @@ public CompletableFuture reset() { slidingWindowService.start(walHeader.getAtomicSlidingWindowMaxLength(), recoveryCompleteOffset); } LOGGER.info("reset sliding window to offset: {}", recoveryCompleteOffset); - return trim(recoveryCompleteOffset - 1, true).thenRun(() -> resetFinished.set(true)); + CompletableFuture cf = trim(recoveryCompleteOffset - 1, true) + .thenRun(() -> resetFinished.set(true)); + + if (!recoveryMode) { + // Only register metrics when not in recovery mode + return cf.thenRun(this::registerMetrics); + } + return cf; } @Override