tp6 queue队列 安装 守护进程

本文详细介绍了如何在ThinkPHP6中使用Think-Queue实现消息队列,包括安装、配置、创建队列和通知,以及执行队列和守护进程的设置。通过实例演示了如何创建JobTest控制器并调用队列接口,以及解决常见问题如Composer安装错误和超时设置。

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

一、安装tp6-queue

composer require topthink/think-queue

二、创建消息队列

1.安装完成后会在config文件夹下生产queue.php配置文件

2.建议修改default为redis

3.创建队列和通知

1)新增 \app\job\JobTest.php 控制器,在该控制器中添加 fire 方法(注意目录名称job必须是小写)
2)fire方法是消息队列默认调用的方法

namespace app\job;

use think\facade\Db;
use think\Log;
use think\queue\Job;

class JobTest
{
    /**
     * fire方法是消息队列默认调用的方法
     *
     * @param Job $job
     *            当前的任务对象
     * @param array|mixed $data
     *            发布任务时自定义的数据
     */
    public function fire(Job $job, $data)
    {
        while (true) {
            // 有些消息在到达消费者时,可能已经不再需要执行了
            $isJobStillNeedToBeDone = $this->checkDatabaseToSeeIfJobNeedToBeDone($data);
            if (!$isJobStillNeedToBeDone) {
                $job->delete();
                return;
            }
            $isJobDone = $this->doJob($data);
            echo $isJobDone;
            if ($isJobDone) {
                // 如果任务执行成功, 记得删除任务
                $job->delete();
                print(date('Y-m-d H:i:s') . "<info>Hello Job has been done and deleted" . "</info>\n");
            } else {
                if ($job->attempts() > 3) {
                    // 通过这个方法可以检查这个任务已经重试了几次了
                    print(date('Y-m-d H:i:s') . "<warn>Hello Job has been retried more than 3 times!" . "</warn>\n");
                    $job->delete();
                    // 也可以重新发布这个任务
                    // print("<info>Hello Job will be availabe again after 2s."."</info>\n");
                    // $job->release(2); //$delay为延迟时间,表示该任务延迟2秒后再执行
                }
            }
            sleep(1);
        }
    }

    /**
     * 有些消息在到达消费者时,可能已经不再需要执行了
     *
     * @param array|mixed $data
     *            发布任务时自定义的数据
     * @return boolean 任务执行的结果
     */
    private function checkDatabaseToSeeIfJobNeedToBeDone($data)
    {
        return true;
    }

    /**
     * 根据消息中的数据进行实际的业务处理...
     */
    private function doJob($data)
    {
       //
    }
}

4.在项目中创建调用队列的接口

<?php

namespace app\controller;


use think\facade\Queue;


class JobCtrl
{
    /**
     * 一个使用了队列的 action
     */
    public function actionJobTest()
    {

        // 1.当前任务将由哪个类来负责处理。
        // 当轮到该任务时,系统将生成一个该类的实例,并调用其 fire 方法
        $jobHandlerClassName = 'app\job\JobTest@fire';
        // 2.当前任务归属的队列名称,如果为新队列,会自动创建
        $jobQueueName = "AutoJob";
        // 3.当前任务所需的业务数据 . 不能为 resource 类型,其他类型最终将转化为json形式的字符串
        // ( jobData 为对象时,需要在先在此处手动序列化,否则只存储其public属性的键值对)
        $jobData = [
            'ts' => time(),
            'bizId' => uniqid(),
            'a' => 1
        ];
        // 4.将该任务推送到消息队列,等待对应的消费者去执行
        $isPushed = Queue::push($jobHandlerClassName, $jobData, $jobQueueName);
        // database 驱动时,返回值为 1|false ; redis 驱动时,返回值为 随机字符串|false
        if ($isPushed !== false) {
            echo date('Y-m-d H:i:s') . " a new Hello Job is Pushed to the MQ" . "<br>";
        } else {
            echo 'Oops, something went wrong.';
        }
    }
}

三、执行消息队列

1.先调用队列接口:

例如:https://test/actionJobTest

2.在框架目录下开启队列

 php think queue:work --queue AutoJob

AutoJob为设置的队列名称

四、守护进程(Supervisor)

宝塔安装:

        1)在软件商店搜索Supervisor管理器

 2)添加守护进程,按要求添加即可

五、异常错误

1.若使用composer 安装queue报错:

        1)使用composer self-update 命令更新composer

        2)删除composer.lock文件,使用composer clearcache命令,再使用composer update,然后再操作安装queue命令

2.消息队列执行一分钟后自动停止,将超时时间设置为0

         1)php think queue:work --queue AutoJob --timeout=0

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值