thinkphp-queue在使用过程中 遇到的一个教训

栏目: PHP · 发布时间: 5年前

内容简介:在项目中我们使用了适合于关于 thinkphp-queue 的使用可以见这个网址我遇到的问题 就是因为一个配置 当我们在

在项目中我们使用了适合于 thinphp5 的队列 thinphp-queue version v1.1.5 。 正常执行没有问题,但是每隔一段时间就会有很多任务重试。经过排查发现是一个配置的问题。具体可以进入本文来查看一些事项。

关于 thinkphp-queue 的使用可以见这个网址 thinkphp-queue 笔记

我遇到的问题 就是因为一个配置 当我们在 thinkphpapplication 应用目录下创建一个 extra/queue.php 时 我们一般这样创建

return [
    'connector' => 'Database',   // 数据库驱动
        'expire'    =>60,           // 任务的过期时间,默认为60秒; 若要禁用,则设置为 null
        'default'   => 'pic',    // 默认的队列名称
        'table'     => 'jobs',       // 存储消息的表名,不带前缀
//        'dsn'       => [],
];

我天真的以为这个任务过期时间时自动删掉任务的结果不是。

结果通过 \think\queue\connector\Database::pop 这个方法的一个判断得到这样的结果

if (!is_null($this->options['expire'])) {
    $this->releaseJobsThatHaveBeenReservedTooLong($queue);
}

\think\queue\connector\Database::releaseJobsThatHaveBeenReservedTooLong 方法是这样写的(请注意:这个方法是 protected 所以无法在类外部直接调用)

protected function releaseJobsThatHaveBeenReservedTooLong($queue)
    {
        $expired = time() - $this->options['expire'];

        $this->db->name($this->options['table'])
            ->where('queue', $this->getQueue($queue))
            ->where('reserved', 1)
            ->where('reserved_at', '<=', $expired)
            ->update([
                'reserved'    => 0,
                'reserved_at' => null,
                'attempts'    => ['inc', 1]
            ]);
    }

如果过期时间不是 null , 那么就重新将任务更新为未执行任务。

于是我悲哀的任务重复执行来了。。。

所以如果你的任务只执行一次,且你想保留任务的话可以将这个设置项 expire 设置为 null


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Web性能权威指南

Web性能权威指南

Ilya Grigorik / 李松峰 / 人民邮电出版社 / 2013-9 / 69

本书是谷歌公司高性能团队核心成员的权威之作,堪称实战经验与规范解读完美结合的产物。本书目标是涵盖Web 开发者技术体系中应该掌握的所有网络及性能优化知识。全书以性能优化为主线,从TCP、UDP 和TLS 协议讲起,解释了如何针对这几种协议和基础设施来优化应用。然后深入探讨了无线和移动网络的工作机制。最后,揭示了HTTP 协议的底层细节,同时详细介绍了HTTP 2.0、 XHR、SSE、WebSoc......一起来看看 《Web性能权威指南》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

在线进制转换器
在线进制转换器

各进制数互转换器

MD5 加密
MD5 加密

MD5 加密工具