Make PHP-CS happy

This commit is contained in:
Philipp 2025-01-02 21:10:58 +01:00
parent eb0c38f90f
commit 6d77eb9b10
No known key found for this signature in database
GPG key ID: 24A7501396EB5432
2 changed files with 75 additions and 69 deletions

View file

@ -230,7 +230,7 @@ class System
$trace = array_slice($trace, 2 + $offset); $trace = array_slice($trace, 2 + $offset);
$callstack = []; $callstack = [];
$previous = ['class' => '', 'function' => '', 'database' => false]; $previous = ['class' => '', 'function' => '', 'database' => false];
// The ignore list contains all functions that are only wrapper functions // The ignore list contains all functions that are only wrapper functions
$ignore = ['call_user_func_array']; $ignore = ['call_user_func_array'];
@ -250,15 +250,15 @@ class System
// Don't show multiple calls from the Database classes to show the essential parts of the callstack // Don't show multiple calls from the Database classes to show the essential parts of the callstack
$func['database'] = in_array($func['class'], ['Friendica\Database\DBA', 'Friendica\Database\Database']); $func['database'] = in_array($func['class'], ['Friendica\Database\DBA', 'Friendica\Database\Database']);
if ($full || !$previous['database'] || !$func['database']) { if ($full || !$previous['database'] || !$func['database']) {
$classparts = explode("\\", $func['class']); $classparts = explode("\\", $func['class']);
$callstack[] = array_pop($classparts).'::'.$func['function'] . (isset($func['line']) ? ' (' . $func['line'] . ')' : ''); $callstack[] = array_pop($classparts).'::'.$func['function'] . (isset($func['line']) ? ' (' . $func['line'] . ')' : '');
$previous = $func; $previous = $func;
} }
} elseif (!in_array($func['function'], $ignore)) { } elseif (!in_array($func['function'], $ignore)) {
$func['database'] = ($func['function'] == 'q'); $func['database'] = ($func['function'] == 'q');
$callstack[] = $func['function'] . (isset($func['line']) ? ' (' . $func['line'] . ')' : ''); $callstack[] = $func['function'] . (isset($func['line']) ? ' (' . $func['line'] . ')' : '');
$func['class'] = ''; $func['class'] = '';
$previous = $func; $previous = $func;
} }
} }
@ -277,10 +277,13 @@ class System
*/ */
public static function echoResponse(ResponseInterface $response) public static function echoResponse(ResponseInterface $response)
{ {
header(sprintf("HTTP/%s %s %s", header(
sprintf(
"HTTP/%s %s %s",
$response->getProtocolVersion(), $response->getProtocolVersion(),
$response->getStatusCode(), $response->getStatusCode(),
$response->getReasonPhrase()) $response->getReasonPhrase()
)
); );
foreach ($response->getHeaders() as $key => $header) { foreach ($response->getHeaders() as $key => $header) {
@ -701,7 +704,7 @@ class System
if (DI::config()->get('system', 'tosdisplay')) { if (DI::config()->get('system', 'tosdisplay')) {
$rulelist = DI::config()->get('system', 'tosrules') ?: DI::config()->get('system', 'tostext'); $rulelist = DI::config()->get('system', 'tosrules') ?: DI::config()->get('system', 'tostext');
$msg = BBCode::toPlaintext($rulelist, false); $msg = BBCode::toPlaintext($rulelist, false);
foreach (explode("\n", trim($msg)) as $line) { foreach (explode("\n", trim($msg)) as $line) {
$line = trim($line); $line = trim($line);
if ($line) { if ($line) {

View file

@ -45,11 +45,11 @@ class Worker
const LAST_CHECK = 'worker::check'; const LAST_CHECK = 'worker::check';
private static $up_start; private static $up_start;
private static $db_duration = 0; private static $db_duration = 0;
private static $db_duration_count = 0; private static $db_duration_count = 0;
private static $db_duration_write = 0; private static $db_duration_write = 0;
private static $db_duration_stat = 0; private static $db_duration_stat = 0;
private static $lock_duration = 0; private static $lock_duration = 0;
private static $last_update; private static $last_update;
private static $state; private static $state;
/** @var Process */ /** @var Process */
@ -93,7 +93,7 @@ class Worker
Worker\Cron::run(); Worker\Cron::run();
} }
$last_check = $starttime = time(); $last_check = $starttime = time();
self::$state = self::STATE_STARTUP; self::$state = self::STATE_STARTUP;
// We fetch the next queue entry that is about to be executed // We fetch the next queue entry that is about to be executed
@ -116,7 +116,7 @@ class Worker
self::findWorkerProcesses(); self::findWorkerProcesses();
DI::lock()->release(self::LOCK_PROCESS); DI::lock()->release(self::LOCK_PROCESS);
self::$state = self::STATE_REFETCH; self::$state = self::STATE_REFETCH;
$refetched = true; $refetched = true;
} else { } else {
self::$state = self::STATE_SHORT_LOOP; self::$state = self::STATE_SHORT_LOOP;
} }
@ -127,7 +127,7 @@ class Worker
self::$state = self::STATE_LONG_LOOP; self::$state = self::STATE_LONG_LOOP;
if (DI::lock()->acquire(self::LOCK_WORKER, 0)) { if (DI::lock()->acquire(self::LOCK_WORKER, 0)) {
// Count active workers and compare them with a maximum value that depends on the load // Count active workers and compare them with a maximum value that depends on the load
if (self::tooMuchWorkers()) { if (self::tooMuchWorkers()) {
Logger::info('Active worker limit reached, quitting.'); Logger::info('Active worker limit reached, quitting.');
DI::lock()->release(self::LOCK_WORKER); DI::lock()->release(self::LOCK_WORKER);
@ -209,7 +209,7 @@ class Worker
*/ */
public static function entriesExists(): bool public static function entriesExists(): bool
{ {
$stamp = (float)microtime(true); $stamp = (float)microtime(true);
$exists = DBA::exists('workerqueue', ["NOT `done` AND `pid` = 0 AND `next_try` < ?", DateTimeFormat::utcNow()]); $exists = DBA::exists('workerqueue', ["NOT `done` AND `pid` = 0 AND `next_try` < ?", DateTimeFormat::utcNow()]);
self::$db_duration += (microtime(true) - $stamp); self::$db_duration += (microtime(true) - $stamp);
return $exists; return $exists;
@ -253,8 +253,8 @@ class Worker
*/ */
private static function highestPriority(): int private static function highestPriority(): int
{ {
$stamp = (float)microtime(true); $stamp = (float)microtime(true);
$condition = ["`pid` = 0 AND NOT `done` AND `next_try` < ?", DateTimeFormat::utcNow()]; $condition = ["`pid` = 0 AND NOT `done` AND `next_try` < ?", DateTimeFormat::utcNow()];
$workerqueue = DBA::selectFirst('workerqueue', ['priority'], $condition, ['order' => ['priority']]); $workerqueue = DBA::selectFirst('workerqueue', ['priority'], $condition, ['order' => ['priority']]);
self::$db_duration += (microtime(true) - $stamp); self::$db_duration += (microtime(true) - $stamp);
if (DBA::isResult($workerqueue)) { if (DBA::isResult($workerqueue)) {
@ -359,7 +359,7 @@ class Worker
self::$last_update = strtotime($queue['executed']); self::$last_update = strtotime($queue['executed']);
} }
$age = (time() - self::$last_update) / 60; $age = (time() - self::$last_update) / 60;
self::$last_update = time(); self::$last_update = time();
if ($age > 1) { if ($age > 1) {
@ -373,7 +373,7 @@ class Worker
self::execFunction($queue, $include, $argv, true); self::execFunction($queue, $include, $argv, true);
$stamp = (float)microtime(true); $stamp = (float)microtime(true);
$condition = ["`id` = ? AND `next_try` < ?", $queue['id'], DateTimeFormat::utcNow()]; $condition = ["`id` = ? AND `next_try` < ?", $queue['id'], DateTimeFormat::utcNow()];
if (DBA::update('workerqueue', ['done' => true], $condition)) { if (DBA::update('workerqueue', ['done' => true], $condition)) {
DI::keyValue()->set('last_worker_execution', DateTimeFormat::utcNow()); DI::keyValue()->set('last_worker_execution', DateTimeFormat::utcNow());
@ -403,7 +403,7 @@ class Worker
self::$last_update = strtotime($queue['executed']); self::$last_update = strtotime($queue['executed']);
} }
$age = (time() - self::$last_update) / 60; $age = (time() - self::$last_update) / 60;
self::$last_update = time(); self::$last_update = time();
if ($age > 1) { if ($age > 1) {
@ -595,21 +595,21 @@ class Worker
self::coolDown(); self::coolDown();
self::$up_start = microtime(true); self::$up_start = microtime(true);
self::$db_duration = 0; self::$db_duration = 0;
self::$db_duration_count = 0; self::$db_duration_count = 0;
self::$db_duration_stat = 0; self::$db_duration_stat = 0;
self::$db_duration_write = 0; self::$db_duration_write = 0;
self::$lock_duration = 0; self::$lock_duration = 0;
if ($duration > 3600) { if ($duration > 3600) {
Logger::info('Longer than 1 hour.', ['priority' => $queue['priority'], 'id' => $queue['id'], 'duration' => round($duration/60, 3)]); Logger::info('Longer than 1 hour.', ['priority' => $queue['priority'], 'id' => $queue['id'], 'duration' => round($duration / 60, 3)]);
} elseif ($duration > 600) { } elseif ($duration > 600) {
Logger::info('Longer than 10 minutes.', ['priority' => $queue['priority'], 'id' => $queue['id'], 'duration' => round($duration/60, 3)]); Logger::info('Longer than 10 minutes.', ['priority' => $queue['priority'], 'id' => $queue['id'], 'duration' => round($duration / 60, 3)]);
} elseif ($duration > 300) { } elseif ($duration > 300) {
Logger::info('Longer than 5 minutes.', ['priority' => $queue['priority'], 'id' => $queue['id'], 'duration' => round($duration/60, 3)]); Logger::info('Longer than 5 minutes.', ['priority' => $queue['priority'], 'id' => $queue['id'], 'duration' => round($duration / 60, 3)]);
} elseif ($duration > 120) { } elseif ($duration > 120) {
Logger::info('Longer than 2 minutes.', ['priority' => $queue['priority'], 'id' => $queue['id'], 'duration' => round($duration/60, 3)]); Logger::info('Longer than 2 minutes.', ['priority' => $queue['priority'], 'id' => $queue['id'], 'duration' => round($duration / 60, 3)]);
} }
Logger::info('Process done.', ['function' => $funcname, 'priority' => $queue['priority'], 'retrial' => $queue['retrial'], 'id' => $queue['id'], 'duration' => round($duration, 3)]); Logger::info('Process done.', ['function' => $funcname, 'priority' => $queue['priority'], 'retrial' => $queue['retrial'], 'id' => $queue['id'], 'duration' => round($duration, 3)]);
@ -639,7 +639,7 @@ class Worker
} }
// Or it can be granted. This overrides the system variable // Or it can be granted. This overrides the system variable
$stamp = (float)microtime(true); $stamp = (float)microtime(true);
$r = DBA::p('SHOW GRANTS'); $r = DBA::p('SHOW GRANTS');
self::$db_duration += (microtime(true) - $stamp); self::$db_duration += (microtime(true) - $stamp);
while ($grants = DBA::fetch($r)) { while ($grants = DBA::fetch($r)) {
$grant = array_pop($grants); $grant = array_pop($grants);
@ -655,7 +655,7 @@ class Worker
$stamp = (float)microtime(true); $stamp = (float)microtime(true);
$used = 0; $used = 0;
$sleep = 0; $sleep = 0;
$data = DBA::p("SHOW PROCESSLIST"); $data = DBA::p("SHOW PROCESSLIST");
while ($row = DBA::fetch($data)) { while ($row = DBA::fetch($data)) {
if ($row['Command'] != 'Sleep') { if ($row['Command'] != 'Sleep') {
++$used; ++$used;
@ -734,13 +734,13 @@ class Worker
* With exponent 1, you could have 20 max queues at idle and 13 at 37% of $maxsysload. * With exponent 1, you could have 20 max queues at idle and 13 at 37% of $maxsysload.
*/ */
$exponent = intval(DI::config()->get('system', 'worker_load_exponent', 3)); $exponent = intval(DI::config()->get('system', 'worker_load_exponent', 3));
$slope = pow(max(0, $maxsysload - $load) / $maxsysload, $exponent); $slope = pow(max(0, $maxsysload - $load) / $maxsysload, $exponent);
$queues = intval(ceil($slope * $maxqueues)); $queues = intval(ceil($slope * $maxqueues));
$processlist = ''; $processlist = '';
if (DI::config()->get('system', 'worker_jpm')) { if (DI::config()->get('system', 'worker_jpm')) {
$intervals = explode(',', DI::config()->get('system', 'worker_jpm_range')); $intervals = explode(',', DI::config()->get('system', 'worker_jpm_range'));
$jobs_per_minute = []; $jobs_per_minute = [];
foreach ($intervals as $interval) { foreach ($intervals as $interval) {
if ($interval == 0) { if ($interval == 0) {
@ -750,7 +750,7 @@ class Worker
} }
$stamp = (float)microtime(true); $stamp = (float)microtime(true);
$jobs = DBA::count('workerqueue', ["`done` AND `executed` > ?", DateTimeFormat::utc('now - ' . $interval . ' minute')]); $jobs = DBA::count('workerqueue', ["`done` AND `executed` > ?", DateTimeFormat::utc('now - ' . $interval . ' minute')]);
self::$db_duration += (microtime(true) - $stamp); self::$db_duration += (microtime(true) - $stamp);
self::$db_duration_stat += (microtime(true) - $stamp); self::$db_duration_stat += (microtime(true) - $stamp);
$jobs_per_minute[$interval] = number_format($jobs / $interval, 0); $jobs_per_minute[$interval] = number_format($jobs / $interval, 0);
@ -769,11 +769,11 @@ class Worker
$waiting_processes = 0; $waiting_processes = 0;
// Now adding all processes with workerqueue entries // Now adding all processes with workerqueue entries
$stamp = (float)microtime(true); $stamp = (float)microtime(true);
$jobs = DBA::p("SELECT COUNT(*) AS `entries`, `priority` FROM `workerqueue` WHERE NOT `done` GROUP BY `priority`"); $jobs = DBA::p("SELECT COUNT(*) AS `entries`, `priority` FROM `workerqueue` WHERE NOT `done` GROUP BY `priority`");
self::$db_duration += (microtime(true) - $stamp); self::$db_duration += (microtime(true) - $stamp);
self::$db_duration_stat += (microtime(true) - $stamp); self::$db_duration_stat += (microtime(true) - $stamp);
while ($entry = DBA::fetch($jobs)) { while ($entry = DBA::fetch($jobs)) {
$stamp = (float)microtime(true); $stamp = (float)microtime(true);
$running = DBA::count('workerqueue-view', ['priority' => $entry['priority']]); $running = DBA::count('workerqueue-view', ['priority' => $entry['priority']]);
self::$db_duration += (microtime(true) - $stamp); self::$db_duration += (microtime(true) - $stamp);
self::$db_duration_stat += (microtime(true) - $stamp); self::$db_duration_stat += (microtime(true) - $stamp);
@ -783,9 +783,9 @@ class Worker
} }
DBA::close($jobs); DBA::close($jobs);
} else { } else {
$waiting_processes = self::totalEntries(); $waiting_processes = self::totalEntries();
$stamp = (float)microtime(true); $stamp = (float)microtime(true);
$jobs = DBA::p("SELECT COUNT(*) AS `running`, `priority` FROM `workerqueue-view` GROUP BY `priority` ORDER BY `priority`"); $jobs = DBA::p("SELECT COUNT(*) AS `running`, `priority` FROM `workerqueue-view` GROUP BY `priority` ORDER BY `priority`");
self::$db_duration += (microtime(true) - $stamp); self::$db_duration += (microtime(true) - $stamp);
self::$db_duration_stat += (microtime(true) - $stamp); self::$db_duration_stat += (microtime(true) - $stamp);
@ -871,7 +871,7 @@ class Worker
*/ */
private static function getWorkerPIDList(): array private static function getWorkerPIDList(): array
{ {
$ids = []; $ids = [];
$stamp = (float)microtime(true); $stamp = (float)microtime(true);
$queues = DBA::p("SELECT `process`.`pid`, COUNT(`workerqueue`.`pid`) AS `entries` FROM `process` $queues = DBA::p("SELECT `process`.`pid`, COUNT(`workerqueue`.`pid`) AS `entries` FROM `process`
@ -896,7 +896,7 @@ class Worker
private static function getWaitingJobForPID() private static function getWaitingJobForPID()
{ {
$stamp = (float)microtime(true); $stamp = (float)microtime(true);
$r = DBA::select('workerqueue', [], ['pid' => getmypid(), 'done' => false]); $r = DBA::select('workerqueue', [], ['pid' => getmypid(), 'done' => false]);
self::$db_duration += (microtime(true) - $stamp); self::$db_duration += (microtime(true) - $stamp);
if (DBA::isResult($r)) { if (DBA::isResult($r)) {
return DBA::toArray($r); return DBA::toArray($r);
@ -920,10 +920,10 @@ class Worker
return []; return [];
} }
$ids = []; $ids = [];
$stamp = (float)microtime(true); $stamp = (float)microtime(true);
$condition = ["`priority` = ? AND `pid` = 0 AND NOT `done` AND `next_try` < ?", $priority, DateTimeFormat::utcNow()]; $condition = ["`priority` = ? AND `pid` = 0 AND NOT `done` AND `next_try` < ?", $priority, DateTimeFormat::utcNow()];
$tasks = DBA::select('workerqueue', ['id', 'command', 'parameter'], $condition, ['limit' => $limit, 'order' => ['retrial', 'created']]); $tasks = DBA::select('workerqueue', ['id', 'command', 'parameter'], $condition, ['limit' => $limit, 'order' => ['retrial', 'created']]);
self::$db_duration += (microtime(true) - $stamp); self::$db_duration += (microtime(true) - $stamp);
while ($task = DBA::fetch($tasks)) { while ($task = DBA::fetch($tasks)) {
$ids[] = $task['id']; $ids[] = $task['id'];
@ -952,7 +952,7 @@ class Worker
*/ */
private static function nextPriority() private static function nextPriority()
{ {
$waiting = []; $waiting = [];
$priorities = [self::PRIORITY_CRITICAL, self::PRIORITY_HIGH, self::PRIORITY_MEDIUM, self::PRIORITY_LOW, self::PRIORITY_NEGLIGIBLE]; $priorities = [self::PRIORITY_CRITICAL, self::PRIORITY_HIGH, self::PRIORITY_MEDIUM, self::PRIORITY_LOW, self::PRIORITY_NEGLIGIBLE];
foreach ($priorities as $priority) { foreach ($priorities as $priority) {
$stamp = (float)microtime(true); $stamp = (float)microtime(true);
@ -966,10 +966,10 @@ class Worker
return self::PRIORITY_CRITICAL; return self::PRIORITY_CRITICAL;
} }
$running = []; $running = [];
$running_total = 0; $running_total = 0;
$stamp = (float)microtime(true); $stamp = (float)microtime(true);
$processes = DBA::p("SELECT COUNT(DISTINCT(`pid`)) AS `running`, `priority` FROM `workerqueue-view` GROUP BY `priority`"); $processes = DBA::p("SELECT COUNT(DISTINCT(`pid`)) AS `running`, `priority` FROM `workerqueue-view` GROUP BY `priority`");
self::$db_duration += (microtime(true) - $stamp); self::$db_duration += (microtime(true) - $stamp);
while ($process = DBA::fetch($processes)) { while ($process = DBA::fetch($processes)) {
$running[$process['priority']] = $process['running']; $running[$process['priority']] = $process['running'];
@ -984,9 +984,9 @@ class Worker
} }
} }
$active = max(self::activeWorkers(), $running_total); $active = max(self::activeWorkers(), $running_total);
$priorities = max(count($waiting), count($running)); $priorities = max(count($waiting), count($running));
$exponent = 2; $exponent = 2;
$total = 0; $total = 0;
for ($i = 1; $i <= $priorities; ++$i) { for ($i = 1; $i <= $priorities; ++$i) {
@ -1037,7 +1037,7 @@ class Worker
} }
$limit = $fetch_limit * count($pids); $limit = $fetch_limit * count($pids);
} else { } else {
$pids = [getmypid()]; $pids = [getmypid()];
$limit = $fetch_limit; $limit = $fetch_limit;
} }
@ -1046,9 +1046,9 @@ class Worker
// If there is not enough results we check without priority limit // If there is not enough results we check without priority limit
if ($limit > 0) { if ($limit > 0) {
$stamp = (float)microtime(true); $stamp = (float)microtime(true);
$condition = ["`pid` = 0 AND NOT `done` AND `next_try` < ?", DateTimeFormat::utcNow()]; $condition = ["`pid` = 0 AND NOT `done` AND `next_try` < ?", DateTimeFormat::utcNow()];
$tasks = DBA::select('workerqueue', ['id', 'command', 'parameter'], $condition, ['limit' => $limit, 'order' => ['priority', 'retrial', 'created']]); $tasks = DBA::select('workerqueue', ['id', 'command', 'parameter'], $condition, ['limit' => $limit, 'order' => ['priority', 'retrial', 'created']]);
self::$db_duration += (microtime(true) - $stamp); self::$db_duration += (microtime(true) - $stamp);
while ($task = DBA::fetch($tasks)) { while ($task = DBA::fetch($tasks)) {
@ -1083,8 +1083,11 @@ class Worker
$stamp = (float)microtime(true); $stamp = (float)microtime(true);
foreach ($worker as $worker_pid => $worker_ids) { foreach ($worker as $worker_pid => $worker_ids) {
Logger::info('Set queue entry', ['pid' => $worker_pid, 'ids' => $worker_ids]); Logger::info('Set queue entry', ['pid' => $worker_pid, 'ids' => $worker_ids]);
DBA::update('workerqueue', ['executed' => DateTimeFormat::utcNow(), 'pid' => $worker_pid], DBA::update(
['id' => $worker_ids, 'done' => false, 'pid' => 0]); 'workerqueue',
['executed' => DateTimeFormat::utcNow(), 'pid' => $worker_pid],
['id' => $worker_ids, 'done' => false, 'pid' => 0]
);
} }
self::$db_duration += (microtime(true) - $stamp); self::$db_duration += (microtime(true) - $stamp);
self::$db_duration_write += (microtime(true) - $stamp); self::$db_duration_write += (microtime(true) - $stamp);
@ -1246,9 +1249,9 @@ class Worker
$priority = self::PRIORITY_MEDIUM; $priority = self::PRIORITY_MEDIUM;
// Don't fork from frontend tasks by default // Don't fork from frontend tasks by default
$dont_fork = DI::config()->get('system', 'worker_dont_fork', false) || !DI::mode()->isBackend(); $dont_fork = DI::config()->get('system', 'worker_dont_fork', false) || !DI::mode()->isBackend();
$created = DateTimeFormat::utcNow(); $created = DateTimeFormat::utcNow();
$delayed = DBA::NULL_DATETIME; $delayed = DBA::NULL_DATETIME;
$force_priority = false; $force_priority = false;
$run_parameter = array_shift($args); $run_parameter = array_shift($args);
@ -1275,10 +1278,10 @@ class Worker
throw new \InvalidArgumentException('Priority number or task parameter array expected as first argument'); throw new \InvalidArgumentException('Priority number or task parameter array expected as first argument');
} }
$command = array_shift($args); $command = array_shift($args);
$parameters = json_encode($args); $parameters = json_encode($args);
$queue = DBA::selectFirst('workerqueue', ['id', 'priority'], ['command' => $command, 'parameter' => $parameters, 'done' => false]); $queue = DBA::selectFirst('workerqueue', ['id', 'priority'], ['command' => $command, 'parameter' => $parameters, 'done' => false]);
$added = 0; $added = 0;
if (!is_int($priority) || !in_array($priority, self::PRIORITIES)) { if (!is_int($priority) || !in_array($priority, self::PRIORITIES)) {
Logger::warning('Invalid priority', ['priority' => $priority, 'command' => $command]); Logger::warning('Invalid priority', ['priority' => $priority, 'command' => $command]);
@ -1292,7 +1295,7 @@ class Worker
if (empty($queue)) { if (empty($queue)) {
if (!DBA::insert('workerqueue', ['command' => $command, 'parameter' => $parameters, 'created' => $created, if (!DBA::insert('workerqueue', ['command' => $command, 'parameter' => $parameters, 'created' => $created,
'priority' => $priority, 'next_try' => $delayed])) { 'priority' => $priority, 'next_try' => $delayed])) {
return 0; return 0;
} }
$added = DBA::lastInsertId(); $added = DBA::lastInsertId();
@ -1354,11 +1357,11 @@ class Worker
*/ */
private static function getNextRetrial(array $queue, int $max_level): int private static function getNextRetrial(array $queue, int $max_level): int
{ {
$created = strtotime($queue['created']); $created = strtotime($queue['created']);
$retrial_time = time() - $created; $retrial_time = time() - $created;
$new_retrial = $queue['retrial'] + 1; $new_retrial = $queue['retrial'] + 1;
$total = 0; $total = 0;
for ($retrial = 0; $retrial <= $max_level + 1; ++$retrial) { for ($retrial = 0; $retrial <= $max_level + 1; ++$retrial) {
$delay = (($retrial + 3) ** 4) + (rand(1, 30) * ($retrial + 1)); $delay = (($retrial + 3) ** 4) + (rand(1, 30) * ($retrial + 1));
$total += $delay; $total += $delay;
@ -1396,7 +1399,7 @@ class Worker
return false; return false;
} }
$id = $queue['id']; $id = $queue['id'];
$priority = $queue['priority']; $priority = $queue['priority'];
$max_level = DI::config()->get('system', 'worker_defer_limit'); $max_level = DI::config()->get('system', 'worker_defer_limit');
@ -1414,7 +1417,7 @@ class Worker
// Calculate the delay until the next trial // Calculate the delay until the next trial
$delay = (($new_retrial + 2) ** 4) + (rand(1, 30) * ($new_retrial)); $delay = (($new_retrial + 2) ** 4) + (rand(1, 30) * ($new_retrial));
$next = DateTimeFormat::utc('now + ' . $delay . ' seconds'); $next = DateTimeFormat::utc('now + ' . $delay . ' seconds');
if (($priority < self::PRIORITY_MEDIUM) && ($new_retrial > 3)) { if (($priority < self::PRIORITY_MEDIUM) && ($new_retrial > 3)) {
$priority = self::PRIORITY_MEDIUM; $priority = self::PRIORITY_MEDIUM;
@ -1426,7 +1429,7 @@ class Worker
Logger::info('Deferred task', ['id' => $id, 'retrial' => $new_retrial, 'created' => $queue['created'], 'next_execution' => $next, 'old_prio' => $queue['priority'], 'new_prio' => $priority]); Logger::info('Deferred task', ['id' => $id, 'retrial' => $new_retrial, 'created' => $queue['created'], 'next_execution' => $next, 'old_prio' => $queue['priority'], 'new_prio' => $priority]);
$stamp = (float)microtime(true); $stamp = (float)microtime(true);
$fields = ['retrial' => $new_retrial, 'next_try' => $next, 'executed' => DBA::NULL_DATETIME, 'pid' => 0, 'priority' => $priority]; $fields = ['retrial' => $new_retrial, 'next_try' => $next, 'executed' => DBA::NULL_DATETIME, 'pid' => 0, 'priority' => $priority];
DBA::update('workerqueue', $fields, ['id' => $id]); DBA::update('workerqueue', $fields, ['id' => $id]);
self::$db_duration += (microtime(true) - $stamp); self::$db_duration += (microtime(true) - $stamp);
@ -1445,7 +1448,7 @@ class Worker
{ {
// Calculate the seconds of the start and end of the maintenance window // Calculate the seconds of the start and end of the maintenance window
$start = strtotime(DI::config()->get('system', 'maintenance_start')) % 86400; $start = strtotime(DI::config()->get('system', 'maintenance_start')) % 86400;
$end = strtotime(DI::config()->get('system', 'maintenance_end')) % 86400; $end = strtotime(DI::config()->get('system', 'maintenance_end')) % 86400;
Logger::info('Maintenance window', ['start' => date('H:i:s', $start), 'end' => date('H:i:s', $end)]); Logger::info('Maintenance window', ['start' => date('H:i:s', $start), 'end' => date('H:i:s', $end)]);