Laravel 跨多个服务器的任务计划程序,无重叠

Laravel Task Scheduler across multiple servers without overlap

我想知道是否有人有过使 Laravel 任务计划程序在多个服务器之间不重叠工作的经验。

放在上下文中: 我在负载均衡器后面有 3 个 API 服务器。我知道任务调度程序允许在单个服务器上使用 withoutOverlap 标志,但我如何在我的所有服务器上使用相同的主体?我只希望 1 台服务器 运行 计划任务,而其他 2 台服务器不 运行 它们。

据我所知,我的选择是:

从 2 个服务器中删除 crontab。 我的服务器是自动化的,不想从任何服务器中删除 crontab 作业,因为这会使我的自动化构建复杂化。

编写一个包,使用数据库将任务限制为仅 运行s 的第一个服务器。 我可以做到这一点,但我想知道它是否已经完成(在 google 上找不到任何东西)

有什么建议吗?

已经有人实现了。看看这个作曲家包 https://packagist.org/packages/jdavidbakr/multi-server-event

从 Laravel 5.6+ 开始,此功能开箱即用。

根据 docs,您可以使用 onOneServer 函数来实现它,就像这样...

$schedule->command('report:generate')
            ->fridays()
            ->at('17:00')
            ->onOneServer();