From f1c4c844509065ffae36dc8f02c74d2715deefd3 Mon Sep 17 00:00:00 2001 From: Xiaobing Li Date: Mon, 25 Mar 2024 14:38:30 -0700 Subject: [PATCH 1/2] add a timer for upsert table preloading --- .../java/org/apache/pinot/common/metrics/ServerTimer.java | 2 ++ .../local/upsert/BasePartitionUpsertMetadataManager.java | 4 ++++ 2 files changed, 6 insertions(+) diff --git a/pinot-common/src/main/java/org/apache/pinot/common/metrics/ServerTimer.java b/pinot-common/src/main/java/org/apache/pinot/common/metrics/ServerTimer.java index 6093a0f76b93..8dbfd706bd44 100644 --- a/pinot-common/src/main/java/org/apache/pinot/common/metrics/ServerTimer.java +++ b/pinot-common/src/main/java/org/apache/pinot/common/metrics/ServerTimer.java @@ -49,6 +49,8 @@ public enum ServerTimer implements AbstractMetrics.Timer { TOTAL_CPU_TIME_NS("nanoseconds", false, "Total query cost (thread cpu time + system " + "activities cpu time + response serialization cpu time) for query processing on server."), + UPSERT_PRELOAD_TIME_MS("milliseconds", false, + "Total time taken to preload a table partition of an upsert table with upsert snapshot"), UPSERT_REMOVE_EXPIRED_PRIMARY_KEYS_TIME_MS("milliseconds", false, "Total time taken to delete expired primary keys based on metadataTTL or deletedKeysTTL"), UPSERT_SNAPSHOT_TIME_MS("milliseconds", false, "Total time taken to take upsert table snapshot"); diff --git a/pinot-segment-local/src/main/java/org/apache/pinot/segment/local/upsert/BasePartitionUpsertMetadataManager.java b/pinot-segment-local/src/main/java/org/apache/pinot/segment/local/upsert/BasePartitionUpsertMetadataManager.java index a97bb659221f..b9f556d602dd 100644 --- a/pinot-segment-local/src/main/java/org/apache/pinot/segment/local/upsert/BasePartitionUpsertMetadataManager.java +++ b/pinot-segment-local/src/main/java/org/apache/pinot/segment/local/upsert/BasePartitionUpsertMetadataManager.java @@ -199,7 +199,11 @@ public void preloadSegments(IndexLoadingConfig indexLoadingConfig) { return; } // From now on, the _isPreloading flag is true until the segments are preloaded. + long startTime = System.currentTimeMillis(); doPreloadSegments(tableDataManager, indexLoadingConfig, helixManager, segmentPreloadExecutor); + long duration = System.currentTimeMillis() - startTime; + _serverMetrics.addTimedTableValue(_tableNameWithType, ServerTimer.UPSERT_PRELOAD_TIME_MS, duration, + TimeUnit.MILLISECONDS); } catch (Exception e) { // Even if preloading fails, we should continue to complete the initialization, so that TableDataManager can be // created. Once TableDataManager is created, no more segment preloading would happen, and the normal segment From 1818cd488f182ba500b3333dffb063afb7f7bd56 Mon Sep 17 00:00:00 2001 From: Xiaobing Li Date: Mon, 25 Mar 2024 14:51:04 -0700 Subject: [PATCH 2/2] add failure meter too --- .../main/java/org/apache/pinot/common/metrics/ServerMeter.java | 1 + .../segment/local/upsert/BasePartitionUpsertMetadataManager.java | 1 + 2 files changed, 2 insertions(+) diff --git a/pinot-common/src/main/java/org/apache/pinot/common/metrics/ServerMeter.java b/pinot-common/src/main/java/org/apache/pinot/common/metrics/ServerMeter.java index e8819ca9459a..02005a3814be 100644 --- a/pinot-common/src/main/java/org/apache/pinot/common/metrics/ServerMeter.java +++ b/pinot-common/src/main/java/org/apache/pinot/common/metrics/ServerMeter.java @@ -53,6 +53,7 @@ public enum ServerMeter implements AbstractMetrics.Meter { DELETED_KEYS_TTL_PRIMARY_KEYS_REMOVED("rows", false), METADATA_TTL_PRIMARY_KEYS_REMOVED("rows", false), UPSERT_MISSED_VALID_DOC_ID_SNAPSHOT_COUNT("segments", false), + UPSERT_PRELOAD_FAILURE("count", false), ROWS_WITH_ERRORS("rows", false), LLC_CONTROLLER_RESPONSE_NOT_SENT("messages", true), LLC_CONTROLLER_RESPONSE_COMMIT("messages", true), diff --git a/pinot-segment-local/src/main/java/org/apache/pinot/segment/local/upsert/BasePartitionUpsertMetadataManager.java b/pinot-segment-local/src/main/java/org/apache/pinot/segment/local/upsert/BasePartitionUpsertMetadataManager.java index b9f556d602dd..81e5dbaecd16 100644 --- a/pinot-segment-local/src/main/java/org/apache/pinot/segment/local/upsert/BasePartitionUpsertMetadataManager.java +++ b/pinot-segment-local/src/main/java/org/apache/pinot/segment/local/upsert/BasePartitionUpsertMetadataManager.java @@ -211,6 +211,7 @@ public void preloadSegments(IndexLoadingConfig indexLoadingConfig) { // normal segment loading logic, the one doing more costly checks on the upsert metadata. _logger.warn("Failed to preload segments from partition: {} of table: {}, skipping", _partitionId, _tableNameWithType, e); + _serverMetrics.addMeteredTableValue(_tableNameWithType, ServerMeter.UPSERT_PRELOAD_FAILURE, 1); if (e instanceof InterruptedException) { // Restore the interrupted status in case the upper callers want to check. Thread.currentThread().interrupt();