Laravel 任务和队列 101:如何在生产服务器上运行你的 worker
发布日期:作者: Youghourta Benali
现在你已经从 第一部分 和 第二部分 开始构建你的第一个基于队列/任务的 Laravel 应用程序,现在是时候将它部署到生产服务器了。
与“常规”Laravel 应用程序(即没有队列和任务的应用程序)相比,唯一的区别是,我们需要告诉服务器运行queue:work
命令并使其持续运行,即使我们关闭了与服务器的 ssh 连接,甚至在重启服务器后也是如此。
我们将探讨如何通过两种不同的方式来实现这一点。第一种方式也是最简单的方式,是使用 Forge,这是部署 Laravel 应用程序的事实上的服务。然后我们将看到如何在没有 Forge 的情况下进行部署,换句话说,我们将了解 Forge 是如何使队列和 worker 在我们的生产服务器上正常工作的。
使用 Forge 部署
我假设你已经将你的应用程序部署到 Forge,我会重点关注接下来要做什么,以便让queue:work
命令在后台运行。
所以,前往 Forge 上的应用程序,然后点击左侧边栏(网站详细信息)上的“队列”选项卡。
我们只需要填写表单,就可以创建我们的后台 worker(s),如下所示
注意: 我们不需要所有字段,以下是最重要的字段
-
连接
:rabbitmq
(我们的队列连接的名称) -
队列
:jobs
。在上一篇文章中,我们有两个队列,一个叫jobs
,另一个叫emails
。我们将为每个队列创建一个新的 worker。 -
进程
:4
。这里我们指定了我们想要多少个后台 worker 来并行消费队列。在上一篇文章中的示例中,我们一次处理一个任务。如果我们的服务器有足够的资源,并且我们希望更快地消费队列,我们可以为同一个队列创建任意数量的进程。 -
最大尝试次数
:3
。这里我们告诉我们的应用程序在将任务标记为失败任务(即发送到failed_jobs
表)之前,尝试执行同一个任务 3 次。
这也取决于你的应用程序的性质。在某些应用程序中,你可能希望在将任务标记为失败之前多次尝试执行同一个任务,而在其他应用程序中,最好立即将任务标记为失败。
现在,在你点击“启动 worker”按钮后,它将出现在“活动 worker”表中
如你所见,你可以从这个表中重新启动或完全删除 worker。
你可能在这里注意到的唯一问题是,如果你想更新 worker,即使只是更新 worker 的数量,你也需要从头开始重新创建 worker。
下一步是什么?
在通过 Forge 创建 worker 后,你无需再做任何操作。即使在重新部署应用程序或重启服务器后,Forge 也会处理所有事情,包括确保 worker 正在运行,并在每次代码更改后重新启动它们。
在没有 Laravel Forge 的情况下部署
在没有 Forge 的情况下部署将向我们展示 Forge 在幕后到底做了多少工作。
让我们看看为了让我们的 worker 在生产服务器上运行,需要哪些步骤。
安装 Supervisor
为了确保我们的queue:work
命令始终运行,我们需要在服务器上安装一个进程监视器,比如 Supervisor。
如果你使用的是 Ubuntu,可以通过以下命令安装它
sudo apt-get install supervisor
配置 Supervisor
我们需要告诉 Supervisor 我们想要消费哪些队列,以及我们想要创建多少个 worker。
为了做到这一点,我们需要为每个队列创建一个配置文件,并将它们存储在/etc/supervisor/conf.d
目录中
配置文件如下所示(示例取自 Laravel 文档)
[program:laravel-worker]process_name=%(program_name)s_%(process_num)02dcommand=php /home/forge/app.com/artisan queue:work sqs --sleep=3 --tries=3autostart=trueautorestart=trueuser=forgenumprocs=8redirect_stderr=truestdout_logfile=/home/forge/app.com/worker.logstopwaitsecs=3600
以下配置文件将重新创建我们在上一节使用 Forge 创建的相同配置
[program:jobs-worker]process_name=%(program_name)s_%(process_num)02dcommand=php /home/djug/basic-analytics-v01/artisan queue:work rabbitmq --queue=jobs --tries=3autostart=trueautorestart=trueuser=djugnumprocs=4redirect_stderr=truestdout_logfile=/home/djug/basic-analytics-v01/worker.log
在你添加了所有需要的配置文件后,你需要执行以下命令,以使新的更改生效
sudo supervisorctl rereadsudo supervisorctl updatesudo supervisorctl start all
每次更新配置文件时,你都需要执行相同的操作
结论
在本系列文章中,我们探索了所有能够让你创建基于任务的 Laravel 应用程序的主题。我们了解了如何创建 Laravel 任务,以及如何使用不同的队列连接来处理它们。我们还了解了为了让我们的 worker 在生产服务器上正常工作,我们需要做些什么。
后端开发人员 http://youghourta.com 我构建了
- botmarker.com
- bookmarkingBot.com
- todocol.com
我也是“Laravel 测试 101”的作者 http://laraveltesting101.com