laravel消息队列如何使用

这篇博客介绍了如何在 Laravel 应用中创建并使用队列任务来批量上传视频资源到抖音平台。首先,通过 Artisan 命令 `php artisan make:job DyUploadResource` 生成队列任务类,定义了任务的尝试次数、超时时间和构造函数,以接收和验证上传数据。接着,在控制器中使用 `dispatch` 函数分发任务,并指定队列名称。最后,通过 `php artisan queue:work --queue=dy_resource_get_status` 命令监听并执行队列任务。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

业务场景:项目里边有很多视频资源需要上传到抖音资源库,通过队列一条一条上传。
(1)创建任务【生成任务类】
在你的应用程序中,队列的任务类都默认放在 app/Jobs 目录下。如果这个目录不存在,那当你运行 make:job Artisan 命令时目录就会被自动创建。你可以用以下的 Artisan 命令来生成一个新的队列任务

php artisan make:job DyUploadResource

任务类结构
任务类的结构很简单,一般来说只会包含一个让队列用来调用此任务的 handle 方法。

<?php

namespace App\Jobs;

use App\Models\HtQuestLibraryQuest;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
class DyUploadResource implements ShouldQueue
{
	use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;

	/**
	 * 任务最大尝试次数。
	 *
	 * @var int
	 */
	public $tries = 5;

	/**
	 * 任务失败前允许的最大异常数
	 *
	 * @var int
	 */
	public $maxExceptions = 3;

	/**
	 * 任务运行的超时时间。
	 *
	 * @var int
	 */
	public $timeout = 600;

	/**
	 * 课程信息
	 *
	 * @var int
	 */
	public $product_data;

    /**
     * 抖音资源上传
     *
     * @return void
     */
    public function __construct(array $product_data)
    {
		$this->product_data = $product_data;

		if(empty($product_data)){

            exit();
		}
    }

    /**
     * Execute the job.
     * 里边写代码逻辑
     * @return bool
     */
    public function handle(): bool
	{
		
    }

}

(2)分发任务【如何使用】

<?php

namespace App\Http\Controllers;

use App\Jobs\ProcessPodcast;
use Illuminate\Http\Request;
use App\Http\Controllers\Controller;

class PodcastController extends Controller
{
     /**
     * 抖音资源课程上传
     */
    public function dyUploadResource(Request $request)
    {
  		// dispatch 用于分发,onQueue 用户起名,监听使用  
  		// ->delay(Carbon::now()->addMinutes(10))  延迟分发
        DyUploadResourceMiddle::dispatch($product_data)->onQueue('dy_resource_get_status');
        
    }
}

(3)监听队列
php artisan queue:work --queue=dy_resource_get_status

开启后队列会执行redis已入队的值
在这里插入图片描述

redis队列任务:
在这里插入图片描述

### Laravel 消息队列使用教程 #### 配置消息队列服务连接 为了配置消息队列,在 `config/queue.php` 文件中定义了多种驱动程序,包括数据库、Redis 和 Amazon SQS 等。每种驱动都有其特定的配置选项[^1]。 ```php 'redis' => [ 'driver' => 'redis', 'connection' => 'default', 'queue' => env('REDIS_QUEUE', 'default'), 'retry_after' => 90, ], ``` #### 定义任务类 通过 Artisan 命令创建一个新的作业类: ```bash php artisan make:job ProcessPodcast ``` 该命令会在 `app/Jobs` 目录下生成一个新文件。在这个类里可以编写处理逻辑。 ```php <?php namespace App\Jobs; use Illuminate\Bus\Queueable; use Illuminate\Contracts\Queue\ShouldQueue; use Illuminate\Foundation\Bus\Dispatchable; use Illuminate\Queue\InteractsWithQueue; use Illuminate\Queue\SerializesModels; class SendEmail implements ShouldQueue { use Dispatchable, InteractsWithQueue, Queueable, SerializesModels; protected $details; /** * Create a new job instance. * * @return void */ public function __construct($details) { $this->details = $details; } /** * Execute the job. * * @return void */ public function handle() { // 发送邮件的具体实现... } } ``` #### 把任务推送到队列 可以通过调用静态方法 `dispatch()` 来推送任务到队列中执行: ```php SendEmail::dispatch(['email' => 'example@example.com']); ``` #### 处理失败的任务 当某个任务多次尝试仍然无法成功完成时会被认为是失败的任务。这些未成功的实例会存储在一个特殊的 "failed_jobs" 表内以便后续分析和重试。 ```sql CREATE TABLE failed_jobs ( id BIGINT AUTO_INCREMENT PRIMARY KEY, uuid VARCHAR(255), connection TEXT NOT NULL, queue TEXT NOT NULL, payload LONGTEXT NOT NULL, exception TEXT NOT NULL, failed_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ); ``` #### 启动工作进程监听器 要让服务器持续监控并消费来自不同队列的消息,则需运行如下命令启动 worker 进程: ```bash php artisan queue:work ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值