From 5617d177b56398dd4e64c4fcd5e82394cdc674b9 Mon Sep 17 00:00:00 2001 From: Tim Brooks Date: Mon, 8 Aug 2022 17:09:51 -0600 Subject: [PATCH] Add logging in GlobalCheckpointSyncIT The test GlobalCheckpointSyncIT#testBackgroundGlobalCheckpointSync failed once recently due to an engine already close exception. It has not occurred again and the reasoning is unclear. This commit adds a log line to indicate exactly when it happens, which shard it is, and what the current state of the index shard is. Closes #88428. --- .../index/seqno/GlobalCheckpointSyncIT.java | 22 ++++++++++++++----- 1 file changed, 16 insertions(+), 6 deletions(-) diff --git a/server/src/internalClusterTest/java/org/elasticsearch/index/seqno/GlobalCheckpointSyncIT.java b/server/src/internalClusterTest/java/org/elasticsearch/index/seqno/GlobalCheckpointSyncIT.java index 5b7ba93405d61..9bf6f24a9015d 100644 --- a/server/src/internalClusterTest/java/org/elasticsearch/index/seqno/GlobalCheckpointSyncIT.java +++ b/server/src/internalClusterTest/java/org/elasticsearch/index/seqno/GlobalCheckpointSyncIT.java @@ -8,6 +8,7 @@ package org.elasticsearch.index.seqno; +import org.apache.lucene.store.AlreadyClosedException; import org.elasticsearch.client.internal.Client; import org.elasticsearch.cluster.node.DiscoveryNode; import org.elasticsearch.cluster.node.DiscoveryNodes; @@ -194,12 +195,21 @@ private void runGlobalCheckpointSyncTest( for (IndexService indexService : indicesService) { for (IndexShard shard : indexService) { if (shard.routingEntry().primary()) { - final SeqNoStats seqNoStats = shard.seqNoStats(); - assertThat( - "shard " + shard.routingEntry() + " seq_no [" + seqNoStats + "]", - seqNoStats.getGlobalCheckpoint(), - equalTo(seqNoStats.getMaxSeqNo()) - ); + try { + final SeqNoStats seqNoStats = shard.seqNoStats(); + assertThat( + "shard " + shard.routingEntry() + " seq_no [" + seqNoStats + "]", + seqNoStats.getGlobalCheckpoint(), + equalTo(seqNoStats.getMaxSeqNo()) + ); + } catch (AlreadyClosedException e) { + logger.error( + "received unexpected AlreadyClosedException when fetching stats for shard: {}, shard state: {}", + shard.shardId(), + shard.state() + ); + throw e; + } } } }