У меня очень дорогой запрос, который выполняется с php, и для его выполнения может потребоваться некоторое время. Есть ли способ в php определить, отключается ли пользователь до выполнения запроса, и отменить его?
2 ответа
Возможное решение - использовать pg_send_query () , эта функция отправляет запрос в базу данных и немедленно возвращает без блокировки. Затем вы можете опросить, чтобы узнать, отключился ли пользователь до завершения запроса. Видеть это:
ignore_user_abort(false);
$db = pg_connect(DATABASE_DSN);
pg_send_query($db, "SELECT pg_sleep(10000)"); // long running query
while(pg_connection_busy($db)) {
/* You need to output something to the browser so PHP can know when the
browser disconnected. The 0 character will be ignored.
*/
echo chr(0);
/* Need to do both flushes to make sure the chr is sent to the browser */
ob_flush();
flush();
usleep(100000); // 0.1s to avoid starving the CPU
if(connection_status() != CONNECTION_NORMAL || connection_aborted()) {
// Browser disconnected, cleanup an die
pg_cancel_query($db);
pg_query($db, "ROLLBACK");
pg_close($db);
die();
}
}
// At this point the query finished and you can continue fetching the rows
Этот подход работает, но имеет большую проблему: вам действительно нужно отправить что-то в браузер, чтобы обнаружить отключение браузера. В противном случае connection_status () и connection_aborted () работать не будут. Похоже, это старая ошибка PHP, см. Здесь: https://bugs.php.net /bug.php?id=30301
Таким образом, этот метод не работает, когда, например, вы запрашиваете Postgres в середине процедуры создания PDF. В этом случае необходимый chr (0) сломает сгенерированный двоичный файл.
Вы могли бы использовать connection_aborted
, чтобы определить, отключился ли пользователь, он возвращает 1, если клиент отключился, иначе он возвращает 0. Есть некоторая документация здесь, однако его использование самодокументируется, и у вас не должно возникнуть проблем с его использованием.
Похожие вопросы
Новые вопросы
php
PHP - это широко используемый высокоуровневый, динамический, объектно-ориентированный и интерпретируемый язык сценариев, в первую очередь предназначенный для серверной веб-разработки. Используется для вопросов о языке PHP.