溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Laravel 8 隊列系統(tǒng)的新功能和變化有哪些

發(fā)布時間:2021-03-02 10:37:20 來源:億速云 閱讀:278 作者:清風 欄目:編程語言

本文將為大家詳細介紹“Laravel 8 隊列系統(tǒng)的新功能和變化有哪些”,內(nèi)容步驟清晰詳細,細節(jié)處理妥當,而小編每天都會更新不同的知識點,希望這篇“Laravel 8 隊列系統(tǒng)的新功能和變化有哪些”能夠給你意想不到的收獲,請大家跟著小編的思路慢慢深入,具體內(nèi)容如下,一起去收獲新知識吧。

Laravel 是什么

Laravel 是一套簡潔、優(yōu)雅的PHP Web開發(fā)框架。它可以讓你從面條一樣雜亂的代碼中解脫出來;它可以幫你構(gòu)建一個完美的網(wǎng)絡APP,而且每行代碼都可以簡潔、富于表達力。

Laravel 8 附帶了很酷的新特性,并對隊列系統(tǒng)的一些更改。在本文中,我們將研究這些特性和更改。

變化


Backoff (回退)

已將 retryAfter() 方法和 retryAfter 排隊作業(yè),郵件,通知和偵聽器的屬性重命名為backoff

php artisan queue:work 命令的 --delay 選項也已重命名為 --backoff。

您還應該知道,現(xiàn)在可以將數(shù)組傳遞給 backoff 屬性,以指示 worker 實現(xiàn)指數(shù)回退 (exponential backoff):

public $backoff = [30, 60];

或者從 backoff() 方法返回一個數(shù)組:

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

在這里使用指數(shù)回退,我們指示 worker 在第一次失敗后延遲 30 秒重試作業(yè),然后在每次失敗后延遲 60 秒。

您還可以在 queue:work 命令上使用指數(shù)回退:

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

作業(yè)過期

排隊作業(yè),通知和偵聽器的 timeoutAt 屬性已重命名為 retryUntil

使用 $retryUntil 指示 worker 繼續(xù)重試作業(yè),直到將來的某個時間為止。

您可以將 retryUntil 作為作業(yè)類的公共屬性或 retryUntil 方法添加:

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

新特性

隊列閉包

您現(xiàn)在可以在調(diào)度隊列閉包時鏈式調(diào)用 catch() 方法:

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

如果作業(yè)失敗,將調(diào)用提供給 catch() 方法的閉包。

數(shù)據(jù)庫驅(qū)動程序可靠性

當使用數(shù)據(jù)庫隊列驅(qū)動程序?qū)⒆鳂I(yè)釋放回隊列時,Laravel 現(xiàn)在將在事務內(nèi)執(zhí)行操作。這意味著除非添加了新的已發(fā)布實例,否則不會從隊列中刪除作業(yè)。這大大減少了作業(yè)失敗的機會。

Redis 驅(qū)動程序效率

當使用 Redis 隊列驅(qū)動程序批量分發(fā)一組作業(yè)時, Laravel 將通過向 Redis 發(fā)送單個命令來執(zhí)行操作。以前, Laravel曾經(jīng)向 Redis 發(fā)送多個 rpush 命令,每個作業(yè)一個。

Worker 優(yōu)雅終止

從 Laravel 8 開始, Workers 將優(yōu)雅退出,并調(diào)用由 App::Terminating() 注冊的任何終止回調(diào)。

Worker 自我終止

為了避免內(nèi)存泄漏,通常的做法是不時終止您的工作程序,然后讓您的過程監(jiān)視工具啟動新的工作程序。通常是通過添加一個運行 queue:restart 令的CRON作業(yè)來完成的。

在 Laravel 8中,您可以指示 Workers 在處理了一定數(shù)量的作業(yè)或運行了特定的秒數(shù)后退出:

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

命名 Workers

你現(xiàn)在添加 --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 并行處理。 您可以在批處理中的所有任務都處理完畢或任何批處理任務失敗后執(zhí)行操作:

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

您可以在官方文檔中找到有關“作業(yè)批處理”的更多信息。

作業(yè)鏈

您現(xiàn)在可以使用 Bus 直接調(diào)度一系列作業(yè):

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

您還可以添加一個 catch() 回調(diào),如果鏈中的任何作業(yè)失敗都會被調(diào)用:

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 擴展工作程序池時要添加或刪除的最大工作進程數(shù)。在 Horizon 的早期版本中,僅添加或刪除了一個工作進程,現(xiàn)在您可以控制該數(shù)目。

至于 balanceCooldown ,它設置每個縮放操作之間等待的秒數(shù)。在 Horizon 的早期版本中,這被硬編碼為3秒。

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

如果你能讀到這里,小編希望你對“Laravel 8 隊列系統(tǒng)的新功能和變化有哪些”這一關鍵問題有了從實踐層面最深刻的體會,具體使用情況還需要大家自己動手實踐使用過才能領會,如果想閱讀更多相關內(nèi)容的文章,歡迎關注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI