• Laravel使用Queue队列的技巧汇总


    Laravel 队列为不同的后台队列服务提供统一的 API,例如 Beanstalk,Amazon SQS,Redis,甚至其他基于关系型数据库的队列。队列的目的是将耗时的任务延时处理,比如发送邮件,从而大幅度缩短 Web 请求和相应的时间。

    队列配置文件存放在 config/queue.php 。每一种队列驱动的配置都可以在该文件中找到,包括数据库,Beanstalkd ,Amazon SQS,Redis,以及同步(本地使用)驱动。其中还包含了一个 null 队列驱动用于那些放弃队列的任务

    1,为什么使用队列?

    一般来说使用队列是为了:

    1,异步,

    2,重试

    也许你还有其他的理由使用队列,但是这应该是最基本的两个原因。

    耗时比较久的,比如上传一个文件后进行一些格式的转化等。

    需要保证送达率的,比如发送短信,因为要调用别人的 api,总会有几率失败,那么为了保证送达,重试就必不可少了。

    使用队列的时候一定要想明白一个问题,这个任务到底是不是可以异步,如果因为异步会导致问题,那么就要放弃使用队列。

    2,驱动的必要设置

    database.php

    在 database.php 配置文件中对 redis 数据库部分进行配置,默认有一个 default 连接,就用这个好了:)
    根据这个默认连接中需要的配置项,编辑 .env 配置文件,将其中的 REDIS_HOST、REDIS_PASSWORD、REDIS_PORT 填写成自己服务器中 Redis 的相应值。

    queue.php

    首先需要去 .env 中配置 QUEUE_DRIVER,因为现在打算用 Redis,所以配置成 redis。

    接着配置 queue.php 里 connections 部分的 redis 连接,其中 connection 对应的值就是 database.php 中 redis 的那个 default 连接。

    数据库

    要使用 database 这个队列驱动的话,你需要创建一个数据表来存储任务。

    你可以用 queue:table 这个 Artisan

    php artisan queue:table

    处理失败的任务

    有时候你队列中的任务会失败。不要担心,本来事情就不会一帆风顺。

    Laravel 内置了一个方便的方式来指定任务重试的最大次数。当任务超出这个重试次数后,它就会被插入到 failed_jobs 数据表里面。要创建 failed_jobs 表的迁移文件,你可以用 queue:failed-table 命令,接着使用 migrate Artisan 命令生成 failed_jobs 表:

    php artisan queue:failed-table

    当迁移创建好以后,就可以用 migrate 这条命令来创建数据表

    php artisan migrate

    3,执行命令讲解

    php artisan queue:work --daemon --quiet --queue=default --delay=3 --sleep=3 --tries=3
     
    

    --daemon 
    queue:work Artisan命令包含一个--daemon选项,用于强制队列工作者继续处理作业,而不必重新启动框架。与queue:listen命令相比,这会显著降低CPU使用率
    总体来说,在 supervisor 中一般要加这个 option,可以节省 CPU 使用。

    --quiet
    不输出任何内容


    --delay=3
    一个任务失败后,延迟多长时间后再重试,单位是秒。这个值的设定我个人建议不要太短,因为一个任务失败(比如网络原因),重试时间太短可能会出现连续失败的情况。


    --sleep=3
    去 Redis 中拿任务的时候,发现没有任务,休息多长时间,单位是秒。这个值的设定要看你的任务是否紧急,如果是那种非常紧急的任务,不能等待太长时间。


    --tries=3
    定义失败任务最多重试次数。这个值的设定根据任务的重要程度来确定,一般 3 次比较适合。

    4,创建任务

    生成任务类

    在你的应用程序中,队列的任务类都默认放在 app/Jobs 目录下。如果这个目录不存在,那当你运行 make:job Artisan 命令时目录就会被自动创建。你可以用以下的 Artisan 命令来生成一个新的队列任务:

    php artisan make:job Demo

    生成的类实现了 Illuminate\Contracts\Queue\ShouldQueue 接口,这意味着这个任务将会被推送到队列中,而不是同步执行。

    1. namespace App\Jobs;
    2. use Illuminate\Bus\Queueable;
    3. use Illuminate\Queue\SerializesModels;
    4. use Illuminate\Queue\InteractsWithQueue;
    5. use Illuminate\Contracts\Queue\ShouldQueue;
    6. use Illuminate\Foundation\Bus\Dispatchable;
    7. use Illuminate\Support\Facades\Log;
    8. class Demo implements ShouldQueue
    9. {
    10. use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
    11. public $param;
    12. /**
    13. * Create a new job instance.
    14. *
    15. * @return void
    16. */
    17. public function __construct($param = '')
    18. {
    19. $this->param = $param;
    20. }
    21. /**
    22. * Execute the job.
    23. *
    24. * @return void
    25. */
    26. public function handle()
    27. {
    28. Log::info('Hello, '.$this->param);
    29. }
    30. }

    控制器代码

    1. public function queue_demo()
    2. {
    3. $num = rand(1,999999999);
    4. // 这个任务将被分发到默认队列...
    5. DemoJob::dispatch($num);
    6. }

    5,开启队列

    php artisan queue:work --queue=default

    由于是本地,需要打开监听,当访问到接口时,就会触发队列中的任务

    线上的话需要用到supervisor的配置

    6,Supervisor 配置

    安装 Supervisor

    Supervisor 是一个 Linux 操作系统上的进程监控软件,它会在 queue:listen 或 queue:work 命令发生失败后自动重启它们。在 Ubuntu 安装 Supervisor,可以用以下命令:

    sudo apt-get install supervisor

    {tip} 如果自己手动配置 Supervisor 听起来有点难以应付,可以考虑使用 Laravel Forge,它能给你的 Laravel 项目自动安装与配置 Supervisor。

    配置 Supervisor

    Supervisor 的配置文件一般是放在 /etc/supervisor/conf.d 目录下。在这个目录中你可以创建任意数量的配置文件来要求 Supervisor 怎样监控你的进程。例如我们创建一个 laravel-worker.conf 来启动与监控一个 queue:work 进程:

    1. [program:laravel-worker]
    2. process_name=%(program_name)s_%(process_num)02d
    3. command=php /home/forge/app.com/artisan queue:work sqs --sleep=3 --tries=3
    4. autostart=true
    5. autorestart=true
    6. user=forge
    7. numprocs=8
    8. redirect_stderr=true
    9. stdout_logfile=/home/forge/app.com/worker.log

    这个例子里的 numprocs 命令会要求 Supervisor 运行并监控 8 个 queue:work 进程,并且在它们运行失败后重新启动。当然,你必须更改 command 命令的 queue:work sqs ,以显示你所选择的队列驱动。

    启动 Supervisor 当这个配置文件被创建后,你需要更新 Supervisor 的配置,并用以下命令来启动该进程:

    1. sudo supervisorctl reread
    2. sudo supervisorctl update
    3. sudo supervisorctl start laravel-worker:*

  • 相关阅读:
    redis如何保证接口的幂等性
    composer 包开发
    @GrpcServise 注解的作用和使用
    ribbon负载均衡
    Android修改开机动画
    未来:spring响应式编程 Hands-On Reactive Programming in Spring 5(三),spring事件监听
    Linux安装MySQL8.0.29,并使用Navicat连接
    Shell脚本之正则表达式详解
    nginx 配置错误目录遍历漏洞
    RustDay05------Exercise[41-50]
  • 原文地址:https://blog.csdn.net/u012322399/article/details/127652615