From be7f20239d24f96ee4f8875818708c6364556666 Mon Sep 17 00:00:00 2001 From: Dmitrii Kustov Date: Fri, 6 Dec 2024 10:37:01 +0200 Subject: [PATCH] Notice about performance --- README.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index d657669..d4fa503 100644 --- a/README.md +++ b/README.md @@ -64,7 +64,8 @@ To trigger processing you need to simply run this: (new \Simbiat\Cron\Agent())->process(10); ``` -where `10` is maximum number of tasks you want to run. It is expected, that you will have it in some .php file, that will be triggered by some system task scheduler (like actual Cron in case of *NIX systems). +where `10` is maximum number of tasks you want to run. It is expected, that you will have it in some .php file, that will be triggered by some system task scheduler (like actual Cron in case of *NIX systems). +**_IMPORTANT_**: Due to the logic of the library related to support of multiple instances of same tasks, the number of actual rows selected from the table will be **double** of the number of passed to `process` function. It should not matter much in case of small number of task instances, but if you have a lot of those, and each `process` needs to select a lot of rows as well, it **will** affect performance. For example, in case of 8 million instances, `process(25)` results in query completing with 25 seconds, while `process(50)` - in 5 minutes, when everything else is under same conditions. This command will do the following: