记一次Laravel 定时任务schedul:run未执行的处理

Posted hilsion

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了记一次Laravel 定时任务schedul:run未执行的处理相关的知识,希望对你有一定的参考价值。

关于Laravel的任务调度(定时任务)的配置在此不做赘述,跟着官方文档一步一步的操作是不会导致定时任务不能正常工作的。
为保证能及时捕获定时任务执行出现异常的原因,只需在配置系统crontab时指定日志文件即可。在执行中出现的任何问题都将会记录在你指定(任意区域,需注意权限)的日志当中。这对于寻找问题原因来说,是极为方便的。

* * * * * cd /path-to-your-project && php artisan schedule:run >> 你的日志文件位置.log 2>&1

以上定时任务确是每分钟执行一次,因此无论成功失败,你都会在你指定的日志中看见最新的输出信息。可使用以下指令查看日志中的输出:

tail -f 你的日志文件位置

以上,就能帮助你很快的捕捉到为何你的Laravel定时任务未执行的原因。除此之外,有一个建议是:在将你的定时任务部署到机器上之前,你应该先通过:

php artisan schedual:run

命令来运行一下你的任务,这样可以在开发阶段就能将大部分的问题都处理掉。当然前提是,调用的任务是每分钟执行的,否则的话,该命令只有在符合你所定义的时间间隔时才会去执行你的任务。
最后,提及一个我自己遇到的问题。若你使用root账户创建了定时任务,则无需在定时任务脚本中加入root账户名称。如下:

* * * * * root cd /path-to-your-project && php artisan schedule:run >> 你的日志文件位置.log 2>&1

在我的ubuntu机器上,这样做直接会报错:

/bin/sh:root:command not found

接原因是使用root账户创建crontab定时任务后,该定时任务文件就保存在了/var/spool/cron/root中,因此无需再指定root账户。
文中难免有疏漏,若存在,烦请责正!
PS:以上文中所有指令均为手打,在此不对指令拼写的正确性与各平台的适用性做任何保证。若出现相关问题,烦请自行bing。

以上是关于记一次Laravel 定时任务schedul:run未执行的处理的主要内容,如果未能解决你的问题,请参考以下文章

记一次定时任务没有执行的原因

记一次定时备份任务的失败原因

记一次简单的清理挖矿程序过程

记一次服务器inodes数报警的事件

记一次数据库查询超时优化问题

记一次并发引起的问题及排查过程