thinkphp6 如何使用think-queue实现消息队列

think-queue 是thinkphp 官方提供的一个消息队列服务,它支持消息队列的一些基本特性

think-queue 是thinkphp 官方提供的一个消息队列服务,它支持消息队列的一些基本特性

  • 消息的发布,获取,执行,删除,重发,失败处理,延迟执行,超时控制等
  • 队列的多队列, 内存限制 ,启动,停止,守护等
  • 消息队列可降级为同步执行

1.安装队列依赖

composer require topthink/think-queue

2.配置文件

安装完 think-queue 后会在 config 目录中生成 queue.php,这个文件是队列的配置文件。

tp6中提供了多种消息队列的实现方式,默认使用sync,我这里选择使用Redis。

<?php
return [
    'default'     => 'redis',
    'connections' => [
        'sync'     => [
            'type' => 'sync',
        ],
        'database' => [
            'type'  => 'database',
            'queue' => 'default',
            'table' => 'jobs',
        ],
        'redis'    => [
            'type'       => 'redis',
            'queue'      => 'default',
            'host'       => '127.0.0.1',
            'port'       => 6379,
            'password'   => '',
            'select'     => 0,
            'timeout'    => 0,
            'persistent' => false,
        ],
    ],
    'failed'      => [
        'type'  => 'none',
        'table' => 'failed_jobs',
    ],
];

3.在项目下新建一个Job目录存放处理消息

thinkphp6 如何使用think-queue实现消息队列

编写对应的消费者类 app/job/Task.php

<?php

namespace app\job;

use think\queue\Job;

class Task
{
    public function fire(Job $job, $data)
    {
        $rt = $this->doJob($data);
        if($rt){
            $job->delete();
            return true;
        }

        // 重试三次失败 todo...
        if($job->attempts() == 3){
            $job->delete();
            return false;
        }

        //执行失败10S后重试
        $job->release(10);


    }

    public function doJob($data)
    {
        echo date('Y-m-d H:i:s')."\n";
        return false;
    }


}

控制器编写逻辑代码

    public function job(Request $request)
    {
        $params = $request->get();
        $jobHandlerClassName = 'app\job\Task'; 
        $jobQueueName = 'task';
        $orderData = ['order_sn'=>$params['id']];
        //Queue::later();//立即执行
        $isPushed = Queue::later(10, $jobHandlerClassName, $orderData, $jobQueueName); //这儿的10是指10秒后执行队列任务
        
        if($isPushed !== false){
            echo '队列添加成功';
        }else{
            echo '插入失败了';
        }
    }

发布任务

think\facade\Queue::push($job, $data = '', $queue = null) 和 think\facade\Queue::later($delay, $job, $data = '', $queue = null) 两个方法,前者是立即执行,后者是在$delay秒后执行

$job 是任务名
单模块的,且命名空间是app\job的,比如上面的例子一,写Job1类名即可
多模块的,且命名空间是app\module\job的,写model/Job1即可
其他的需要些完整的类名,比如上面的例子二,需要写完整的类名app\lib\job\Job2
如果一个任务类里有多个小任务的话,如上面的例子二,需要用@+方法名app\lib\job\Job2@task1app\lib\job\Job2@task2

$data 是你要传到任务里的参数

$queue 队列名,指定这个任务是在哪个队列上执行,同下面监控队列的时候指定的队列名,可不填

4.监听任务并执行

php think queue:listen

php think queue:work

两种,具体的可选参数可以输入命令加 –help 查看

可配合supervisor使用,保证进程常驻

thinkphp6 如何使用think-queue实现消息队列

以上这篇thinkphp6 如何使用think-queue实现消息队列就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持芦苇派。

原创文章,作者:ECHO陈文,如若转载,请注明出处:https://www.luweipai.cn/php/1664506156/

  • 7