отправить данные в фоновый скрипт php

0

Иногда у меня длинная задача, и я не хочу, чтобы текущий поток 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
Теги:
multithreading

2 ответа

1
Лучший ответ

Вы можете просто отправить данные через 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
  • 0
    Сколько данных может быть отправлено в качестве аргумента?
  • 0
    @ user1032531 Я ожидаю более 1 КБ: stackoverflow.com/questions/6846263/…
1

Если целью является возвращение статуса клиенту и продолжение обработки, вам может быть проще просто сделать что-то вроде этого.

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, а не просто запустить ее как дочерний процесс текущая нить.

  • 0
    Это цель. Мне нужно будет проверить это. Спасибо
  • 0
    Я думаю, что это лучшее решение, и хотелось бы, чтобы я проголосовал за него не раз. Другой ответ, однако, ответил на мой конкретный вопрос.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню