有很多关于设置cron的教程,我想我已经做得正确,但由于某种原因,它无法正常工作。我还创建了一个控制器类来测试模型,并且它正常工作。在Magento中设置CRON作业
这里是我的config.xml:
<config>
<modules>
<VPS_Export>
<version>0.1.0</version>
</VPS_Export>
</modules>
<global>
<models>
<vps_export>
<class>VPS_Export_Model</class>
</vps_export>
</models>
<helpers>
<vps_export>
<class>VPS_Export_Helper</class>
</vps_export>
</helpers>
</global>
<frontend>
<routers>
<vps_export>
<use>standard</use>
<args>
<module>VPS_Export</module>
<frontName>vpsexport</frontName>
</args>
</vps_export>
</routers>
</frontend>
<crontab>
<jobs>
<vps_export>
<schedule>
<cron_expr>*/5 * * * *</cron_expr><!-- every 5 minutes -->
</schedule>
<run>
<model>vps_export/observer::exportProducts</model>
</run>
</vps_export>
</jobs>
</crontab>
</config>
我Observer.php文件是:
<?php
class VPS_Export_Model_Observer
{
public function exportProducts()
{
echo "VPS Export Products called!";
Mage::Log("exportProducts called!");
}
}
?>
而且我的测试IndexController.php文件是:
<?php
class VPS_Export_IndexController extends Mage_Core_Controller_Front_Action
{
public function indexAction()
{
echo "index action called!";
Mage::getModel('vps_export/observer')->exportProducts();
}
}
?>
如果我点我的浏览器在http:// my_server/vpsexport/index我看到从t他回应声明并将消息打印到日志中,所以我知道该模型已正确配置。但是,cron并没有得到相同的结果。如果我手动运行cron.php,我没有遇到任何错误,但它仍然没有做任何事情。
有什么想法?
手动运行cron后,你的db中的'cron_schedule'表中有什么东西吗? – OSdave 2011-04-13 07:54:56
我以前不知道cron_schedule表。是的,表中有项目,它们似乎正在执行,但我的日志消息仍然没有记录到日志中。我如何测试以确保它在执行cron作业时确实调用了正确的函数? – BrianVPS 2011-04-13 12:10:24