thinkphp6 queue队列的maxTries自定义

前景需求:在我们用队列的时候发现maxtries的个数时255次,这个太影响其他队列任务

我目前使用的thinkphp版本是6.1

第一部定义一个新的类

复制代码
CustomDataBase(我用的mysql数据库存放的队列)

重写__make 和createPlainPayload方法

复制代码
<?php
namespace app;

use think\Db;
use think\queue\connector\Database;

class CustomDataBase extends Database
{
// 此方法必须有,具体原因自己看源码吧
    public static function __make(Db $db, $config)
    {
        $connection = $db->connect($config['connection'] ?? null);

        return new self($connection, $config['table'], $config['queue'], $config['retry_after'] ?? 60);
    }
    protected function createPlainPayload($job, $data)
    {
        return [
            'job'      => $job,
            'maxTries' => 22,
            'timeout'  => null,
            'data'     => $data,
        ];
    }
}

第二步修改queue.php文件的配置

为什么要重写类,自己要点Queue::push(),查看源码,因为我的项目通篇用的都是用的类名,最简单的是重写,当然你也可以自己在push的时候写对象,对象里面定义属性$tries=10;

复制代码
Queue::push(EmailJob::class, $email->id);
相关推荐
TheWolfsfaith几秒前
Redis服务键控建通知安装
数据库·redis·缓存
牛马鸡niumasi9 分钟前
Mysql:事务管理(上)
数据库·mysql
IMPYLH13 分钟前
Linux 的 users 命令
linux·运维·服务器·前端·数据库·bash
Nontee14 分钟前
三大范式是什么?
java·前端·数据库
BingoGo19 分钟前
TrueAsync Server 为 PHP 带来了原生的高性能 HTTP 服务器
后端·php
步十人20 分钟前
【MySQL】进阶01-存储引擎
数据库·mysql
六月雨滴27 分钟前
归档日志备份
数据库·oracle·dba
白露与泡影30 分钟前
自己用 ai 写了个链接 mysql 数据库的 mcp 工具
数据库·人工智能·mysql
我是一颗柠檬33 分钟前
【MySQL全面教学】MySQL聚合函数与分组Day5(2026年)
数据库·后端·mysql·database
祁白_33 分钟前
PHP无参RCE
web安全·php·ctf·writeup