Attempt at eliminating cron contention.

git-svn-id: https://develop.svn.wordpress.org/trunk@4509 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Ryan Boren 2006-11-21 02:48:12 +00:00
parent 2e848a43e4
commit 64262206e2
1 changed files with 9 additions and 1 deletions

View File

@ -6,6 +6,11 @@ require_once('wp-config.php');
if ( $_GET['check'] != md5(DB_PASS . '187425') ) if ( $_GET['check'] != md5(DB_PASS . '187425') )
exit; exit;
if ( get_option('doing_cron') > time() )
exit;
update_option('doing_cron', time() + 30);
$crons = _get_cron_array(); $crons = _get_cron_array();
$keys = array_keys($crons); $keys = array_keys($crons);
if (!is_array($crons) || $keys[0] > time()) if (!is_array($crons) || $keys[0] > time())
@ -14,14 +19,17 @@ foreach ($crons as $timestamp => $cronhooks) {
if ($timestamp > time()) break; if ($timestamp > time()) break;
foreach ($cronhooks as $hook => $keys) { foreach ($cronhooks as $hook => $keys) {
foreach ($keys as $key => $args) { foreach ($keys as $key => $args) {
do_action_ref_array($hook, $args['args']);
$schedule = $args['schedule']; $schedule = $args['schedule'];
if ($schedule != false) { if ($schedule != false) {
$new_args = array($timestamp, $schedule, $hook, $args['args']); $new_args = array($timestamp, $schedule, $hook, $args['args']);
call_user_func_array('wp_reschedule_event', $new_args); call_user_func_array('wp_reschedule_event', $new_args);
} }
wp_unschedule_event($timestamp, $hook, $args['args']); wp_unschedule_event($timestamp, $hook, $args['args']);
do_action_ref_array($hook, $args['args']);
} }
} }
} }
update_option('doing_cron', 0);
?> ?>