まず、カスタムcronジョブスケジュールを定義します。
add_filter('cron_schedules', array($this, 'cron_schedules'));
public function cron_schedules($schedules){
$prefix = 'cron_';// Avoid conflict with other crons. Example Reference: cron_30_mins
$schedule_options = array(
'30_mins' => array(
'display' => '30 Minutes',
'interval' => '1800'
),
'1_hours' => array(
'display' => 'Hour',
'interval' => '3600'
),
'2_hours' => array(
'display' => '2 Hours',
'interval' => '7200'
)
);
/* Add each custom schedule into the cron job system. */
foreach($schedule_options as $schedule_key => $schedule){
$schedules[$prefix.$schedule_key] = array(
'interval' => $schedule['interval'],
'display' => __('Every '.$schedule['display'])
);
}
return $schedules;
}
実際にイベントをスケジュールする場所とタイミングを決定する必要があります。
カスタムクラスメソッドを呼び出すコードのスニペットの例を次に示します。
$schedule = $this->schedule_task(array(
'timestamp' => current_time('timestamp'), // Determine when to schedule the task.
'recurrence' => 'cron_30_mins',// Pick one of the schedules set earlier.
'hook' => 'custom_imap_import'// Set the name of your cron task.
));
イベントを実際にスケジュールするコードは次のとおりです。
private function schedule_task($task){
/* Must have task information. */
if(!$task){
return false;
}
/* Set list of required task keys. */
$required_keys = array(
'timestamp',
'recurrence',
'hook'
);
/* Verify the necessary task information exists. */
$missing_keys = array();
foreach($required_keys as $key){
if(!array_key_exists($key, $task)){
$missing_keys[] = $key;
}
}
/* Check for missing keys. */
if(!empty($missing_keys)){
return false;
}
/* Task must not already be scheduled. */
if(wp_next_scheduled($task['hook'])){
wp_clear_scheduled_hook($task['hook']);
}
/* Schedule the task to run. */
wp_schedule_event($task['timestamp'], $task['recurrence'], $task['hook']);
return true;
}
これで、カスタムcronタスクの名前を呼び出すだけで済みます。この例では、cronタスク名はcustom_imap_import
です。
add_action('custom_imap_import', array($this, 'do_imap_import'));
public function do_imap_import(){
// .... Do stuff when cron is fired ....
}
したがって、この例で$this->do_imap_import();
は、30分ごとに呼び出されます(Webサイトへのトラフィックが十分にあると仮定)。
ノート
cronを適切なタイミングで起動するには、ページにアクセスする必要があります。
例: 30分間隔でタスクをスケジュールしたが、誰も4時間サイトにアクセスしなかった場合、その訪問者が4時間後にサイトにアクセスするまで、cronジョブは実行されません。本当に30分ごとにタスクを実行する必要がある場合は、Webホスティングプロバイダーを介して正当なcronジョブをセットアップし、目的の間隔でWebサイトにアクセスすることをお勧めします。
WordPressのcronジョブはあなたのウェブサイトを遅くしません!
cronスクリプトの実行に時間がかかる場合、訪問者はスクリプトが実行されるまで待たなければならないのではないかと考えているかもしれません。いや!どうしてそれが可能ですか?wp-cron.php
ファイルを見ると、行があります
ignore_user_abort(true);
これphp.ini
は、サイト/スクリプトの読み込みを停止しても、スクリプトの実行が停止しないように設定する構成です。
wp-includes/cron.php
ファイルを見ると、次のような行があります。
wp_remote_post( $cron_url,
array('timeout' => 0.01,
'blocking' => false,
'sslverify' => apply_filters('https_local_ssl_verify', true)) );
つまり、WordPressは実行をトリガーするのに0.01秒しか待機せず、中止しますが、スクリプトに設定ignore_user_abort
しtrue
たとおりに実行されます。この機能は、WordPress cronジョブで大きなスクリプトを実行するための大きな利点です。
支援に利用できる機能:
schedule_event( $_SESSION['insert_id'] );
解雇されますか?