视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Laravel 8 队列系统的新功能和变化
2020-11-02 18:23:24 责编:小采
文档
下面由Laravel教程栏目给大家介绍Laravel 8 队列系统的新功能和变化,希望对需要的朋友有所帮助!

Laravel 8 附带了很酷的新特性,并对队列系统的一些更改。在本文中,我们将研究这些特性和更改。

变化


Backoff (回退)

已将 retryAfter() 方法和 retryAfter 排队作业,邮件,通知和侦听器的属性重命名为backoff

php artisan queue:work 命令的 --delay 选项也已重命名为 --backoff

您还应该知道,现在可以将数组传递给 backoff 属性,以指示 worker 实现指数回退 (exponential backoff):

public $backoff = [30, 60];

或者从 backoff() 方法返回一个数组:

public function backoff()
{
 return [30, 60]; 
}

在这里使用指数回退,我们指示 worker 在第一次失败后延迟 30 秒重试作业,然后在每次失败后延迟 60 秒。

您还可以在 queue:work 命令上使用指数回退:

php artisan queue:Work --backoff=30,60

作业过期

排队作业,通知和侦听器的 timeoutAt 属性已重命名为 retryUntil

使用 $retryUntil 指示 worker 继续重试作业,直到将来的某个时间为止。

您可以将 retryUntil 作为作业类的公共属性或 retryUntil 方法添加:

public function retryUntil()
{
 return now()->addDay();
}

新特性

队列闭包

您现在可以在调度队列闭包时链式调用 catch() 方法:

dispatch(function () {
 // Job logic...
})->catch(function (Throwable $e) {
 // Handle Failure...
});

如果作业失败,将调用提供给 catch() 方法的闭包。

数据库驱动程序可靠性

当使用数据库队列驱动程序将作业释放回队列时,Laravel 现在将在事务内执行操作。这意味着除非添加了新的已发布实例,否则不会从队列中删除作业。这大大减少了作业失败的机会。

Redis 驱动程序效率

当使用 Redis 队列驱动程序批量分发一组作业时, Laravel 将通过向 Redis 发送单个命令来执行操作。以前, Laravel曾经向 Redis 发送多个 rpush 命令,每个作业一个。

Worker 优雅终止

从 Laravel 8 开始, Workers 将优雅退出,并调用由 App::Terminating() 注册的任何终止回调。

Worker 自我终止

为了避免内存泄漏,通常的做法是不时终止您的工作程序,然后让您的过程监视工具启动新的工作程序。通常是通过添加一个运行 queue:restart 令的CRON作业来完成的。

在 Laravel 8中,您可以指示 Workers 在处理了一定数量的作业或运行了特定的秒数后退出:

php artisan queue:work --max-jobs=1000 --max-time=3600

命名 Workers

你现在添加 --name 选项到 queue:work 命令:

php artisan queue:work --name=notifications

添加此功能的主要目的是允许人们自定义 Workers 在运行时如何选择哪个队列来处理任务:

Worker::popUsing('notifications', function ($pop) {
 $queues = time()->atNight() 
 ? ['mail', 'webhooks'] 
 : ['push-notifications', 'sms', 'mail', 'webhooks'];

 foreach ($queues as $queue) {
 if (! is_null($job = $pop($queue))) {
 return $job;
 }
 }
});

任务批处理

Laravel 的任务批处理使您可以分派许多任务,以供您的 Workers 并行处理。 您可以在批处理中的所有任务都处理完毕或任何批处理任务失败后执行操作:

Bus::batch([
 new ProcessFile(1),
 new ProcessFile(2),
 new ProcessFile(3),
])->dispatch();

您可以在官方文档中找到有关“作业批处理”的更多信息。

作业链

您现在可以使用 Bus 直接调度一系列作业:

Bus::chain([
 new ExtractReports,
 new GenerateReport,
 new SendResults,
])->dispatch();

您还可以添加一个 catch() 回调,如果链中的任何作业失败都会被调用:

Bus::chain([
 new ExtractReports,
 new GenerateReport,
 new SendResults,
])->catch(function(){
 // Handle the chain failure.
})
->dispatch();

Horizon 平衡率

Horizon 中添加了两个新的配置选项: balanceMaxShift and balanceCooldown

 'environments' => [
 'environment' => [
 'supervisor-1' => [
 'balanceMaxShift' => 5,
 ],
 ],
],

balanceMaxShift 设置每次 Horizon 扩展工作程序池时要添加或删除的最大工作进程数。在 Horizon 的早期版本中,仅添加或删除了一个工作进程,现在您可以控制该数目。

至于 balanceCooldown ,它设置每个缩放操作之间等待的秒数。在 Horizon 的早期版本中,这被硬编码为3秒。

 'environments' => [
 'environment' => [
 'supervisor-1' => [
 'balanceCooldown' => 1,
 ],
 ],
],

原文地址:https://dev.to/themsaid/features-and-changes-coming-to-laravel-8-s-queue-system-5amg

译文地址:https://learnku.com/laravel/t/50086

下载本文
显示全文
专题