Cron events that have missed their schedule
The WP-Cron system in WordPress is not a “real” cron system, which means events may not run exactly according to their schedule because the system relies on regular traffic to the website in order to trigger scheduled events.
The WP Crontrol plugin does not alter the way that WordPress core runs or stores cron events.
Reasons WP-Cron events can miss their schedule
- Low traffic websites may not trigger the event runner often enough
- A fatal error caused by a plugin or theme may break the event runner
- A plugin or theme may intentionally or unintentionally break the event runner
- BasicAuth, a firewall, password protection, or other access restrictions may block the event runner
- A problem with your web hosting or web server may break the event runner
- Long-running events may temporarily block the event runner
- High traffic websites may suffer from sequential processing issues that block the event runner
- The
DISABLE_WP_CRON
configuration constant is set but no alternative cron runner has been put in place - An alternative cron runner is in place but is not working as expected or has stalled
How can I fix this?
There’s no single solution to this problem. Your best approach is to:
- Reload the page a few times to determine if the problem is persistent. If the issue only appears occasionally then it could be that low levels of traffic to your site is the cause. Continue reading for more info.
- Read the Problems spawning a call to the WP-Cron system page.
- Deactivate other plugins on your site one by one to see if any of them are causing things to break. Start with ones that you’ve recently updated or recently installed.
- Contact your web hosting provider as they commonly have experience dealing with problems with WP-Cron. They’ll often recommend setting up a server-level cron job to trigger the WP-Cron event runner.
- Read the sections below on how to set up a server-level cron job or reliably run WP-Cron events at a large scale.
Articles with more information
Host-specific instructions
- SiteGround: How to replace WP-Cron with a real cron job
- Pantheon: Configuring and optimizing the WP-Cron feature
- WP Engine: WP-Cron and WordPress event scheduling
- Kinsta: How to Disable WP-Cron for Faster Performance
- DreamHost: Disabling WP-Cron to Improve Overall Site Performance
- Rocket.net: How Do I Disable WP-Cron In WordPress?
- Altis: No need to do anything, cron is handled by Cavalcade
- WordPress VIP: No need to do anything, cron is handled by Cron Control
Running events via WP-CLI
If you have access to WP-CLI and Crontab on your server, you can set up a real schedule in Crontab and use it to run all pending WP-Cron events via WP-CLI. Here are some articles on this topic:
WP-Cron at scale
If you need to process a large number of cron events, your events are long-running, you need parallel processing, or you require high reliability for your cron events, you should consider one of the following:
- Cavalcade, which runs cron at scale on the Altis Cloud platform by Human Made.
- Cron Control, which runs cron at scale on WordPress VIP by Automattic.
Both of these are scalable, horizontally distributed cron runner systems for WordPress which — unlike the default WP-Cron which relies on web requests to trigger scheduled tasks — run as a daemon on your server and ensure that cron events are executed reliably and on time.
Background processing
If you need to perform long-running actions in a background process, try one of these:
If you need an approach that doesn’t use WP-Cron, try one of these: