无法在Cpanel上设置cron作业

时间:2017-10-27 14:25:37

标签: php cron cpanel

尝试在Cpanel上添加一个cron作业,每5分钟运行一次。我将此添加到命令输入(从网址中删除了个人详细信息)

/usr/bin/php -q /home/my_name/public_html/staging/the_web_site/wp-content/themes/my_child_theme/functions.php updateproducts

然后在functions.php,我有这个:

if (!empty($argv[1])) {
    switch ($argv[1]) {
        case "updateproducts":
            update_products(); 
            break;
    }
}

update_products()函数在没有任何错误的情况下运行,如果我使用管理页面上的按钮触发它。但是,无论我在cronjob标签上做什么,它都不会运行。

有什么想法吗?

function update_products() {
   global $wpdb;
   $groups = get_groups_from_cron_jobs(100);
   foreach ( $groups as $group ) {
       $name = $group->group_name;
       $sql = $wpdb->prepare("SELECT * FROM {$wpdb->prefix}products WHERE name='%s'", $name);
       $products = $wpdb->get_results($sql);
       if ( !empty($products) ){
           $post_id = get_post_id_from_products($products);
           //if there isn't a parent_id then create a new product
           if ( !$post_id && $name != '' ) {
               $post_id = create_a_new_product($name);
           }
           // make sure that all products will have now a parent_id
           add_parent_id_on_products($name, $post_id);
           insert_product_attributes($post_id, $products);
           insert_product_variations($post_id, $products);
           delete_group_from_cron_jobs($name);
       }

   }
}

编辑:基于答案/评论,我做了额外的研究,发现我可以在任何脚本上加载$ wpdb。我做的是这个:

if (!empty($argv[1])) {
    switch ($argv[1]) {
        case "updateproducts":
            $path = $_SERVER['DOCUMENT_ROOT'];
            require( $path . '/staging/the_web_site/wp-load.php' );
            update_products(); 
            break;
    }
}

但是,我仍然收到电子邮件错误:

Status: 500 Internal Server Error
X-Powered-By: PHP/5.6.31
Content-type: text/html; charset=UTF-8

1 个答案:

答案 0 :(得分:1)

我担心会对网络环境和控制台环境的互操作性产生一些误解。

简而言之,您的函数期望WordPress存在。它期望用户通过WordPress应用程序访问该函数,并且存在诸如$wpdb之类的全局变量(以及其他内容)。如果您通过管理页面访问此功能,那么这一切都是正确的,并且该功能可以正常工作。

但是如果你通过控制台(命令行)访问这个功能,这都不是真的。 WordPress在该请求的上下文中存在 not global $wpdb不存在,因为该函数尚未通过WordPress访问,而是通过直接命令访问。

如果希望此功能在命令行上运行,则需要重写它以在该环境中工作。这意味着没有特定于WordPress的帮助器或功能。

或者,您可以使用WordPress Crons,这不是真正的Cron作业,而是在访问站点时(在其定义的时间范围内)运行。因此,如果您有一个必须每五分钟运行一次的cron,但是您每隔几分钟就无法可靠地拥有一个新访问者,这些将无法满足您的需求,但它们是一种选择。

http://www.wpbeginner.com/plugins/how-to-view-and-control-wordpress-cron-jobs/