Иногда у меня длинная задача, и я не хочу, чтобы текущий поток PHP ожидал, и я сделал что-то вроде следующего. Передача данных в сеансе немного клочковатая, но, похоже, работает.
У меня есть другое подобное приложение, за исключением того, что file1.php не выполняется клиентом пользователя, а другим сервером, и пользователь получает доступ только к другому серверу. Таким образом, cookie сеанса не будет доступен для session_start()
в файле file1.php, и ему нужно будет создать отдельный файл сеанса для каждого события.
Каковы другие параметры передачи данных на сценарий рабочего стола? Я не передаю огромное количество данных, но все равно будет 1 кб или около того.
file1.php
session_start();
$_SESSION['_xfr']=$_POST;
$status=exec($'/usr/bin/php -q /path/to/my/worker.php'.' '.session_id().' >/dev/null &');
echo('Tell client we are done.');
file2.php
session_id($argv[1]);//Set by parent
session_start();
$data=$_SESSION['_xfr'];
//Do some task
Вы можете просто отправить данные через args, как json:
file1.php
$status=exec($'/usr/bin/php -q /path/to/my/worker.php'.' '.json_encode($_POST).' >/dev/null &');
echo('Tell client we are done.');
file2.php
$data=json_decode($argv[1]);
//Do some task
Если целью является возвращение статуса клиенту и продолжение обработки, вам может быть проще просто сделать что-то вроде этого.
public function closeConnection($body, $responseCode){
// Cause we are clever and don't want the rest of the script to be bound by a timeout.
// Set to zero so no time limit is imposed from here on out.
set_time_limit(0);
// Client disconnect should NOT abort our script execution
ignore_user_abort(true);
// Clean (erase) the output buffer and turn off output buffering
// in case there was anything up in there to begin with.
ob_end_clean();
// Turn on output buffering, because ... we just turned it off ...
// if it was on.
ob_start();
echo $body;
// Return the length of the output buffer
$size = ob_get_length();
// send headers to tell the browser to close the connection
// remember, the headers must be called prior to any actual
// input being sent via our flush(es) below.
header("Connection: close\r\n");
header("Content-Encoding: none\r\n");
header("Content-Length: $size");
// Set the HTTP response code
// this is only available in PHP 5.4.0 or greater
http_response_code($responseCode);
// Flush (send) the output buffer and turn off output buffering
ob_end_flush();
// Flush (send) the output buffer
// This looks like overkill, but trust me. I know, you really don't need this
// unless you do need it, in which case, you will be glad you had it!
@ob_flush();
// Flush system output buffer
// I know, more over kill looking stuff, but this
// Flushes the system write buffers of PHP and whatever backend PHP is using
// (CGI, a web server, etc). This attempts to push current output all the way
// to the browser with a few caveats.
flush();
}
В противном случае ваши варианты ограничены для многопоточности на HTTP-сервере и обстреливают через exec, поскольку вы делаете это другим способом. Однако вам может понадобиться команда nohup, а не просто запустить ее как дочерний процесс текущая нить.