From e3a698d9d79ef8c4ae7e9ed1fe6f6a281eeaa237 Mon Sep 17 00:00:00 2001 From: Dean Herbert Date: Mon, 11 Dec 2023 18:24:13 +0900 Subject: [PATCH] Show overall rate --- .../Commands/Queue/ImportHighScoresCommand.cs | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/osu.Server.Queues.ScoreStatisticsProcessor/Commands/Queue/ImportHighScoresCommand.cs b/osu.Server.Queues.ScoreStatisticsProcessor/Commands/Queue/ImportHighScoresCommand.cs index 67fd60e6..74de1400 100644 --- a/osu.Server.Queues.ScoreStatisticsProcessor/Commands/Queue/ImportHighScoresCommand.cs +++ b/osu.Server.Queues.ScoreStatisticsProcessor/Commands/Queue/ImportHighScoresCommand.cs @@ -80,6 +80,7 @@ public class ImportHighScoresCommand public bool SkipIndexing { get; set; } private long lastCommitTimestamp; + private long startupTimestamp; private long lastLatencyCheckTimestamp; private ElasticQueueProcessor? elasticQueueProcessor; @@ -126,6 +127,8 @@ public class ImportHighScoresCommand public async Task OnExecuteAsync(CancellationToken cancellationToken) { + startupTimestamp = DateTimeOffset.Now.ToUnixTimeMilliseconds(); + if (!CheckSlaveLatency) scoresPerQuery = maximum_scores_per_query; @@ -242,9 +245,12 @@ public async Task OnExecuteAsync(CancellationToken cancellationToken) int inserted = Interlocked.Exchange(ref currentReportInsertCount, 0); int updated = Interlocked.Exchange(ref currentReportUpdateCount, 0); + double secondsPassed = (double)(currentTimestamp - lastCommitTimestamp) / 1000; + double secondsSinceStart = (double)(currentTimestamp - startupTimestamp) / 1000; + Console.WriteLine($"Inserting up to {lastId:N0} " + $"[{runningBatches.Count(t => t.Task.IsCompleted),-2}/{runningBatches.Count}] " - + $"{totalInsertCount:N0} inserted {totalUpdateCount:N0} updated {totalSkipCount:N0} skipped (+{inserted:N0} new +{updated:N0} upd {(inserted + updated) / seconds_between_report:N0}/s)"); + + $"{totalInsertCount:N0} inserted {totalUpdateCount:N0} updated {totalSkipCount:N0} skipped (+{inserted:N0} new +{updated:N0} upd {(inserted + updated) / secondsPassed:N0}/s {(totalInsertCount + totalUpdateCount) / secondsSinceStart})"); lastCommitTimestamp = currentTimestamp; }