From b2c2ce7612543c9a38afd6fa7cc1fdfb923bd2dc Mon Sep 17 00:00:00 2001 From: Jose Celano Date: Wed, 24 Apr 2024 16:35:28 +0100 Subject: [PATCH] feat: increase the tracker stast importer exec interval We are having problems with the live demo server: https://github.com/torrust/torrust-demo/issues/1 Due to a high CPU and memory usage. --- .../cronjobs/tracker_statistics_importer.rs | 32 +++++++++++++------ 1 file changed, 22 insertions(+), 10 deletions(-) diff --git a/src/console/cronjobs/tracker_statistics_importer.rs b/src/console/cronjobs/tracker_statistics_importer.rs index 970fd7ca..7f618e61 100644 --- a/src/console/cronjobs/tracker_statistics_importer.rs +++ b/src/console/cronjobs/tracker_statistics_importer.rs @@ -83,16 +83,28 @@ pub fn start( info!("Tracker statistics importer cronjob starting ..."); - // code-review: we set an execution interval to avoid intense polling to - // the database. If we remove the interval we would be constantly - // queering if there are torrent stats pending to update, unless there - // are torrents to update. Maybe we should only sleep for 100 milliseconds - // if we did not update any torrents in the latest execution. - // With this current limit we can only import 50 torrent stats every 100 - // milliseconds which is 500 torrents per second (1800000 torrents per hour). - // If the tracker can handle a request in 100 milliseconds. - - let execution_interval_in_milliseconds = 100; + // code-review: + // + // We set an execution interval to avoid intense polling to the + // database. If we remove the interval we would be constantly queering + // if there are torrent stats pending to update, unless there are + // torrents to update. Maybe we should only sleep for 100 milliseconds + // if we did not update any torrents in the latest execution. With this + // current limit we can only import 50 torrent stats every 2000 seconds, + // which is 500 torrents per second (1800000 torrents per hour). + // + // | Interval (secs) | Number of torrents imported per hour | + // ------------------|--------------------------------------| + // | 1 sec | 50 * (3600/1) = 180000 | + // | 2 sec | 50 * (3600/2) = 90000 | + // | 3 sec | 50 * (3600/3) = 60000 | + // | 4 sec | 50 * (3600/4) = 45000 | + // | 5 sec | 50 * (3600/5) = 36000 | + // + // The `execution_interval_in_milliseconds` could be a config option in + // the future. + + let execution_interval_in_milliseconds = 2000; let execution_interval_duration = std::time::Duration::from_millis(execution_interval_in_milliseconds); let mut execution_interval = tokio::time::interval(execution_interval_duration);