介绍-Laravel-Horizon

55次阅读

共计 1656 个字符,预计需要花费 5 分钟才能阅读完成。

文章转发自专业的 Laravel 开发者社区,原始链接:https://learnku.com/laravel/t…

今天我得意的宣布 Laravel Horizon, 它为 Laravel Redis 队列提供了精美的仪表盘和代码驱动的配置系统。

除了全新的代码驱动配置系统, Horizon 还有美丽的仪表盘 UI, 它完全开源,对整个 Laravel 社区都是免费的,我们明天发布测试版本,我希望你会喜欢它。

译者注: 截止 2019 年 10 月,Horizon 已经发布了 3.4.1 版本

仪表盘


Horizon 仪表板是一个漂亮的单页 Vue 应用程序,可通过简单的 composer require laravel / horizon 直接安装到现有应用程序中。它提供对队列工作负载,最近的作业,失败的作业,作业重试,吞吐量和运行时指标以及进程计数的实时洞察。通过 Horizon :: auth 注册的简单回调控制仪表板的身份验证,从而使您可以完全控制对仪表板的访问。

配置

Horizon 是配置 Laravel 队列的绝佳新方法。与 Laravel 的调度程序类似,所有队列工作者都可以通过代码配置:


在您的代码中拥有此配置意味着这一切都在源代码控制之下,从而使您的团队可以轻松地进行协作。在 config/horizon.php 文件中,我们配置要创建的进程数量、需要处理的队列、队列超时时间以及需要传递给 queue:work Artisan 命令的其他任何设置。

然后,要启动所有的队列工作者,只需要一个简单的命令:php artisan horizon。不需要其他命令行选项。该命令将读取 Horizon 配置并配置所有必需的工作进程。

将 Horizon 安装并部署到生产环境后,您可以通过修改配置文件并重新部署来修改整个队列工作者的配置。

失败的任务

Horizon 提供了清晰详细的界面,用于检查和重试失败的任务(是的,我们都有)。您可以查看该任务的异常堆栈跟踪,标签和最近重试记录。将失败的任务详细信息直接在页面上显示真是太好了。由于重试是链接到失败的原始任务,因此您不再需要盲目地尝试在控制台输入 queue:retry 并确定其重试是成功完成还是再次失败:

标签监控

Horizon 允许您为任务分配标签,包括 EmailBroadcastsNotificationsQueued Listeners。实际上,Horizon 会根据附加到队列的 Eloquent Model 智能地给大多数任务打上标签。

您可以通过这些标签轻松地搜索到队列任务,从而查看特定的客户任务或者程序中的其他队列任务。此功能使您可以快速关注高价值客户,或为刚提交支持工单的客户找到失败的任务:

平衡


Horizon 可以根据队列的工作负载自动平衡队列中的队列工作进程。例如,如果 default 队列为空,但notifications 队列中充满了队列任务,则 Horizon 可以自动将 notifications 的任务分配到 default 队列中,以帮助快速处理这些任务。

队列赶上后,Horizon 将确保在所有队列中公平地重新分配任务。

指标图表


Horizon 提供吞吐量和平均运行时间图表,使您可以查看单个任务或整个队列的吞吐量和运行时间趋势。这些指标快照是使用 horizon:snapshot 命令捕获的,可以使用 Laravel 内置的任务调度将其设置为每分钟运行一次。这使您可以快速发现部署后的性能下降。

通知


当您的某个队列达到一定负荷时,Horizon 会同时发送 Slack 和 SMS 通知。您可以轻松配置等待时间阈值以确定何时发送通知。这意味着您始终知道何时队列需要更多的处理进程。收到通知后,Horizon 的代码驱动配置使您可以快速进行配置更改以增加更多处理进程。

结论 & 感谢

我要特别感谢 Mohamed Said,David Hemphill 和 Steve Schoger,他们都为 Horizon 的设计和开发做出了贡献。Steve 设计了用户界面,David Hemphill 将其作为 Vue 应用程序实现了接口,Mohamed 将前端连接到了我实现的 Horizon 后端。

正文完
 0