Laravel 8 队列系统的新功能和变化

发布时间 - 2020-09-27 00:00:00    点击率:

下面由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


# laravel  # php  # catch  # 闭包  # redis  # 数据库  # https  # 您可以  # 批处理  # 您的  # 您还  # 命名为  # 您现在  # 或删除  # 链式  # 回调  # 重试 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Chrome浏览器标签页分组怎么用_谷歌浏览器整理标签页技巧【效率】  Laravel Artisan命令怎么自定义_创建自己的Laravel命令行工具完全指南  Laravel如何实现多表关联模型定义_Laravel多对多关系及中间表数据存取【方法】  香港服务器WordPress建站指南:SEO优化与高效部署策略  北京企业网站设计制作公司,北京铁路集团官方网站?  微信推文制作网站有哪些,怎么做微信推文,急?  Laravel如何部署到服务器_线上部署Laravel项目的完整流程与步骤  齐河建站公司:营销型网站建设与SEO优化双核驱动策略  个人摄影网站制作流程,摄影爱好者都去什么网站?  Laravel怎么设置路由分组Prefix_Laravel多级路由嵌套与命名空间隔离【步骤】  iOS验证手机号的正则表达式  网站制作大概多少钱一个,做一个平台网站大概多少钱?  如何在万网自助建站平台快速创建网站?  图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?  C++时间戳转换成日期时间的步骤和示例代码  WordPress 子目录安装中正确处理脚本路径的完整指南  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  网站制作价目表怎么做,珍爱网婚介费用多少?  Python图片处理进阶教程_Pillow滤镜与图像增强  Laravel如何使用withoutEvents方法临时禁用模型事件  如何在建站宝盒中设置产品搜索功能?  Laravel Docker环境搭建教程_Laravel Sail使用指南  Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程  HTML5空格和nbsp有啥关系_nbsp的作用及使用场景【说明】  长沙做网站要多少钱,长沙国安网络怎么样?  如何在阿里云完成域名注册与建站?  企业网站制作这些问题要关注  UC浏览器如何设置启动页 UC浏览器启动页设置方法  Laravel如何监控和管理失败的队列任务_Laravel失败任务处理与监控  Laravel如何处理文件上传_Laravel Storage门面实现文件存储与管理  网页制作模板网站推荐,网页设计海报之类的素材哪里好?  如何在云虚拟主机上快速搭建个人网站?  Laravel怎么使用Session存储数据_Laravel会话管理与自定义驱动配置【详解】  Laravel怎么在Controller之外的地方验证数据  Android滚轮选择时间控件使用详解  Laravel如何实现数据库事务?(DB Facade示例)  如何快速搭建高效香港服务器网站?  C语言设计一个闪闪的圣诞树  JavaScript如何实现路由_前端路由原理是什么  Laravel怎么配置S3云存储驱动_Laravel集成阿里云OSS或AWS S3存储桶【教程】  Laravel如何使用Eloquent进行子查询  想要更高端的建设网站,这些原则一定要坚持!  Gemini手机端怎么发图片_Gemini手机端发图方法【步骤】  laravel怎么实现图片的压缩和裁剪_laravel图片压缩与裁剪方法  Laravel PHP版本要求一览_Laravel各版本环境要求对照  Win11怎么开启自动HDR画质_Windows11显示设置HDR选项  Laravel如何实现全文搜索功能?(Scout和Algolia示例)  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)  Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】