How to set up a WordPress cron job

This article describes how to configure a cron job for WordPress.

The virtual WordPress “cron job”

A cron job is a task scheduled to run automatically at specific intervals. For example, a cron job could automatically back up a file every six hours.

In its default configuration, WordPress does not use a real cron job for scheduling and other related tasks. Instead, whenever a page is loaded on a WordPress site, WordPress runs the wp-cron.php file. Although this “virtual” cron job is convenient, it has a few disadvantages:

  • Running the wp-cron.php file every time WordPress loads a page is unnecessary, and can negatively affect server performance, particularly on sites that receive a lot of traffic.
  • For a site that does not receive a lot of traffic on the other hand, it can be a significant amount of time before a visitor loads a page (and triggers the cron task). This can cause missed schedules for publishing posts and other unintended effects.

To resolve these issues, you can disable the default virtual WordPress cron job, and configure a real cron job. To do this, follow the procedures below.

Disabling the virtual WordPress cron job

To disable the default virtual WordPress cron job, follow these steps:

  1. Log in to your account using cPanel or SSH.
  2. Using the cPanel File Manager or the command line, open the wp-config.php file in a text editor.
    The wp-config.php file is located in the directory where you installed WordPress. Usually, this is the public_html directory.
  3. Add the following line to the wp-config.php file:
    define('DISABLE_WP_CRON', true);

    Make sure you add the previous line before the following line in the wp-config.php file:

    /* That's all, stop editing! Happy publishing. */
    
  4. Save the changes to the wp-config.php file and then exit the text editor. The virtual WordPress cron job is now disabled.

Configuring a real cron job for WordPress

After you have disabled the default WordPress cron configuration in the wp-config.php file, you are ready to set up a real cron job that runs at fixed intervals regardless of site traffic.

If your account includes cPanel access, you can use it to configure the cron job. Alternatively, you can configure the cron job from the command line, or use the A2 Optimized plugin for WordPress.

Method #1: Use cPanel

To set up a WordPress cron job using cPanel, follow these steps:

  1. Log in to cPanel.
  2. In the Advanced section of the cPanel home screen, click Cron jobs.
  3. Under Cron Email, type the e-mail address that you want to receive notifications, and then click Update Email. Every time the cron job runs, the e-mail account will receive a message.
    If you do not want to receive e-mail notifications for the cron job, you can append >/dev/null 2>&1 to the command, which redirects all output to /dev/null.
  4. Under Add New Cron Job, in the Common Settings list box, select Twice an hour.
    You can run cron jobs a maximum of every 15 minutes on shared and reseller accounts. A 30-minute interval for the WordPress cron job should be more than sufficient.
  5. In the Command text box, type the following line:
    cd ${HOME}/public_html; php -q wp-cron.php
    This line assumes that you installed WordPress in the document root (public_html) directory. If you installed WordPress in another directory, modify the cd command to change to that directory instead.
  6. Click Add New Cron Job. The new cron job settings take effect immediately.
Method #2: Use the command line

To set up a WordPress cron job using the command line, follow these steps:

  1. Log in to your account using SSH.
  2. At the command prompt, type the following command:
    crontab -e
  3. Type o to enter editing mode and start a new line of text.
  4. Type the following line, replacing username with your own A2 Hosting account username:

    */30 * * * *  cd ${HOME}/public_html; php -q wp-cron.php
    • This line sets the cron job to run every 30 minutes. If you are on an unmanaged platform you can run cron jobs as frequently as you want. On shared and reseller accounts, however, you can only run cron jobs a maximum of every 15 minutes. A 30-minute interval for the WordPress cron job should be more than sufficient.
    • This line assumes that you installed WordPress in the document root (public_html) directory. If you installed WordPress in another directory, modify the cd command to change to that directory instead.
  5. Press Esc, type :wq and then press Enter. The new cron job settings take effect immediately.
Method #3: Use the A2 Optimized plugin

The A2 Optimized plugin enables you to quickly and easily disable the virtual WordPress cron and enable a system cron instead.

For information about how to install the A2 Optimized plugin on your WordPress site, please see this article.

To enable a system cron job for WordPress using the A2 Optimized plugin, follow these steps:

  1. Log in to WordPress as the administrator.
  2. Under Dashboard, click A2 Optimized:

    A2 Optimized WP - Dashboard menu

  3. Click the Optimization tab:

    A2 Optimized WP - Optimization tab

  4. In the Use System Cron Instead of WordPress Cron section, click the slider to enable the option, and then click Update. A2 Optimized disables the WordPress virtual cron and creates a system cron job:

    A2 Optimized WP - Optimization tab - System cron option

Get WordPress Hosting

Article Details

  • Level: Intermediate

Other Articles in This Category

Show More

Did you find this article helpful? Then you'll love our support. Experience the A2 Hosting difference today and get a pre-secured, pre-optimized website. Check out our web hosting plans today.

We use cookies to personalize the website for you and to analyze the use of our website. You consent to this by clicking on "I consent" or by continuing your use of this website. Further information about cookies can be found in our Privacy Policy.