|
php.net | support | documentation | report a bug | advanced search | search howto | statistics | random bug | login |
[2004-02-17 20:00 UTC] jason at thinkingman dot org
Description:
------------
Hi
I'd like to propose a modification to the SET_TIME_LIMIT() and/or the REGISTER_SHUTDOWN_FUNCTION() or perhaps, the creation of a related new function.
Currently when a page goes to timeout, all buffers get flushed, and all headers get sent. In the interest of handling timeouts better; it would be ** GREAT ** if instead of all this flushing and finalization occuring, if one could also choose to not have the current script flush and finalize; but to remain in the script as if no timeout occurred at all.
This way, when a timeout occurs one can (for example) do redirects, or choose to manually flush and clear buffers, allowing for cleaner INCLUDE implimentations, and so on.
I'm thinking something like the following could be implimented:
set_time_limit(300, true);
Where 'true' means; don't end script; just kick event off stating that timeout has occurred; allowing register_shutdown_function() to be called, if defined... and continuing normal operation of script.
void set_time_limit ( int seconds, [bool: event notify only]); default = false.
// code example:
<?
set_time_limit(300, true);
define("NORMAL", 0);
define("ABORTED", 1);
define("TIMEOUT", 2);
function onShutdownEvent() {
switch(connection_status()) {
case NORMAL:
// code normal exit.
break;
case ABORTED:
// code aborted exit.
break;
case TIMEOUT:
header("location: http://timeout.php");
exit;
break;
}
}
register_shutdown_function('onShutdownEvent');
while(1);
?>
Another example of the TIMEOUT switch might be:
case TIMEOUT:
while(ob_get_level) ob_end_clean();
if($dblink) mysql_close($dblink);
include('./header.html');
include('error.php');
include('./footer.html');
exit;
break;
Thanks,
Jason
PatchesPull RequestsHistoryAllCommentsChangesGit/SVN commits
|
|||||||||||||||||||||||||||||||||||||
Copyright © 2001-2025 The PHP GroupAll rights reserved. |
Last updated: Sat Oct 25 07:00:02 2025 UTC |
This would be really useful on the CLI to stop a script running forever, set the execution time then the script timeout and gracefully shutdown. Currently I have to do this with the Linux timeout command, but it's nasty and means you cannot naively handle timeouts which most other languages can. timeout --signal=SIGHUP 120s script.php .... <?php // Protect from some causes of death function sig_handler($sig) { echo "UNKNOWN, Script Dying: I was killed before the requested work could be completed. (Execution Time " . round((microtime() - $GLOBALS['timer']),2) . " secs)" . PHP_EOL; exit (3); } // Start Timer $timer = microtime(true); // Catch Signals pcntl_signal(SIGINT, "sig_handler"); pcntl_signal(SIGTERM, "sig_handler"); pcntl_signal(SIGHUP, "sig_handler");