friendica/mod/worker.php

59 wiersze
1.2 KiB
PHP
Czysty Zwykły widok Historia

<?php
2016-11-27 09:02:08 +00:00
/**
* @file mod/worker.php
2017-11-19 21:47:21 +00:00
* @brief Module for running the worker as frontend process
2016-11-27 09:02:08 +00:00
*/
use Friendica\Core\Worker;
use Friendica\Core\Config;
use Friendica\Core\PConfig;
function worker_init($a){
2017-02-26 23:16:49 +00:00
if (!Config::get("system", "frontend_worker")) {
return;
}
2016-12-01 20:53:18 +00:00
// We don't need the following lines if we can execute background jobs.
// So we just wake up the worker if it sleeps.
if (function_exists("proc_open")) {
Worker::executeIfIdle();
return;
}
Worker::clearProcesses();
$workers = q("SELECT COUNT(*) AS `processes` FROM `process` WHERE `command` = 'worker.php'");
if ($workers[0]["processes"] > Config::get("system", "worker_queues", 4)) {
return;
}
$a->start_process();
logger("Front end worker started: ".getmypid());
Worker::callWorker();
if ($r = Worker::workerProcess()) {
2016-11-27 10:01:24 +00:00
// On most configurations this parameter wouldn't have any effect.
// But since it doesn't destroy anything, we just try to get more execution time in any way.
set_time_limit(0);
if (poller_claim_process($r[0])) {
Worker::execute($r[0]);
}
}
Worker::callWorker();
Worker::unclaimProcess();
$a->end_process();
logger("Front end worker ended: ".getmypid());
killme();
}