问下laravel的定时任务,如何能多个任务一起执行?
我发现laravel执行console里面的定时任务,是一个接着一个的执行,我就想问下能不能搞个多进程什么的,能够一起执行这些定时任务,主要是有些定时任务很耗时,等这些定时任务执行完,时间就过去了。
高认可度评论:
可以 用 runInBackground 方法
如果条件允许,可以把部分业务放到队列中去执行。
可以 用 runInBackground 方法
你要是能解决多个进程操作同一个数据的问题,可以启多个进程执行
直接用swoole算了
直接放到任务队列中 任务调度《Laravel 9 中文文档》
楼上说的
runInBackground
方法可以试试正好去年的时候也遇到同样的问题, 当时也是耗时的操作如果不并行的话会特别的耗费时间。当时是用 swoole 的线程池线程池解决问题,实现过程比较复杂,结果也不是特别满意。 当时虽然解决了并行的问题, 但是没有解决耗费时间的问题。 因为我内个耗时的任务也特别耗费cpu占用。 并行两个以上的话,cpu 占用会直接到 100% (4核8g),所以只能限制并行最多同时两个, 感觉复杂度和回报不成正比。
后来优化成 自己用redis实现一个可以管理并行任务数量的任务管理器。 任务管理器不处理任务,直接通过事件的广播发送到本地机器处理了。 em... 这个实现也有一点复杂, 但是比上面那个上限要高。
任务管理器和 horizon 差不多..
horizon 如果不考虑我上面说的 cpu 和 内存占用的问题的话, Horizon 应该可以配置多个进程运行队列 https://learnku.com/docs/laravel/10.x/horizon/14906#balancing-strategies, 你也可以将任务推送到不同的队列, 不同的队列应该也是并行的。 队列《Laravel 10 中文文档》
最好是这样写,一劳永逸: 在 schedule 方法最后这么写,设置所有定时任务都后台执行