thinkphp使用think-queue队列,使用supervisor实现常驻进程

安装

使用composer安装拓展包

composer require topthink/think-queue

默认安装是最新版的,如果不是tp6,使用2.0版本

composer require topthink/think-queue 2.0

配置

配置文件位于 config/queue.php

[
    'connector'=>'sync' //驱动类型,可选择 sync(默认):同步执行,database:数据库驱动,redis:Redis驱动,topthink:Topthink驱动
                   //或其他自定义的完整的类名
]

推荐用redis,使用database时,每3秒就会访问一次数据库,日志生成超级多,好无语

任务类

创建job类

attempts() > 3) {
                  //通过这个方法可以检查这个任务已经重试了几次了
             }
            //如果任务执行成功后 记得删除任务,不然这个任务会重复执行,直到达到最大重试次数后失败后,执行failed方法
            $job->delete();
            // 也可以重新发布这个任务
            $job->release($delay); //$delay为延迟时间

    }
    public function failed($data){
        // ...任务达到最大重试次数后,失败了
    }
}

调用并且发布任务

在控制器调用队列

$data=['key'=>'value'];
//延迟两小时执行
Queue::later(2*60*60,'app\job\RegisterPushJobs',$data);
//即刻执行
Queue::push(2*60*60,'app\job\RegisterPushJobs',$data);

监听任务并执行的指令

php think queue:listen
php think queue:work --daemon(不加--daemon为执行单个任务)

通过supervisor实现常驻进程

安装supervisor之后,supervisor配置文件可以看到,可以在 supervisord.d目录下自定义增加后缀为ini的配置文件

[include]
files = supervisord.d/*.ini

在etc/supervisord.d目录下创建queue.ini

[program:queue_worker] ;项目名称
directory = /www/wwwroot/tp5.com ;目录,项目根目录的上一级
command = php think queue:listen --queue zhan,hai ; 启动命令 zhan 就是队列名,多个队列就用逗号拼接起来
process_name=%(program_name)s_%(process_num)02d
numprocs = 3         ; 开启的进程数量
autostart = true     ; 在 supervisord 启动的时候也自动启动
startsecs = 5        ; 启动 5 秒后没有异常退出,就当作已经正常启动了
autorestart = true   ; 程序异常退出后自动重启
startretries = 3     ; 启动失败自动重试次数,默认是 3
user = root          ; 用哪个用户启动
redirect_stderr = true  ; 把 stderr 重定向到 stdout,默认 false
stdout_logfile_maxbytes = 50MB  ; stdout 日志文件大小,默认 50MB
stdout_logfile_backups = 20     ; stdout 日志文件备份数
; stdout 日志文件,需要手动创建目录(supervisord 会自动创建日志文件)
stdout_logfile = /usr/local/supervisor/log/queue_worker.log ;日志的位置
loglevel=info

重启supervisor

systemctl restart supervisord

拓展,supervisor常用指令

#查看任务状态,可以查看单个任务状态: supervisorctl status 服务名
supervisorctl status 
#启动任务
supervisorctl start 服务名
#停止任务
supervisorctl start 服务名
#重启任务
supervisorctl restart 服务名
#当增加任务配置文件后,可以更新任务
supervisorctl update       //配置文件修改后使用该命令加载新的配置
supervisorctl reload        //重新启动配置中的所有程序
supervisorctl shutdown   //关闭supervisord
supervisorctl clear 进程名 //清空进程日志

你可能感兴趣的:(thinkphp使用think-queue队列,使用supervisor实现常驻进程)