Laravel 的任务调度时间间隔是假的吗?

$schedule->call(function(){
    Log::debug('332211');
})->everyMinute();

代码是每分钟打印一次日志
但是我每秒运行一次
php artisan schedule:run
都会打印日志,这样那个每分钟一点用处没有啊

xingchen
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 1
堂堂糖唐

laravel的任务调度逻辑是这样的。
如果你设置频次是5分钟一次,在执行schedule:run的时候会判断当前时间的分钟数是不是5分钟的倍数。
比如你在12:05的时候执行调度命令,就会生效。
且你在12:05这一分钟的时间里,执行多次都会生效,等时间走到12:06时,你再执行命令就无效了。
如果设置成一分钟一次,那就相当于任意时刻执行都会生效。
当然,你自己本地这样操作肯定会存在间隔问题,但是你在服务器上使用crontab每分钟执行一次命令,就不会存在这个问题。

4年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!