lumen队列的配置和使用

问题一、为什么使用队列?

一般来说:1.异步  2.重试

问题二、什么情况使用队列?

简单举例:

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

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


lumen队列的配置和使用:

队列的配置在 .env QUEUE_DRIVER 选项里,暂时用database
如果你想完全自定义配置信息,你可以复制 vendor/laravel/lumen-framework/config/queue.php 整个文件到 config/queue.php 中,根目录如果没有 config 的话你应该创建一个。
添加队列表:
$php artisan make:migration create_jobs_table --create=jobs
  1. Schema::create('jobs',function(Blueprint$table) {
  1.     $table->bigIncrements('id');
  1.     $table->string('queue');
  1.     $table->longText('payload');
  1.     $table->tinyInteger('attempts')->unsigned();
  1.     $table->tinyInteger('reserved')->unsigned();
  1.     $table->unsignedInteger('reserved_at')->nullable();
  1.     $table->unsignedInteger('available_at');
  1.     $table->unsignedInteger('created_at');
  1.     $table->index(['queue','reserved','reserved_at']);
  1. });

添加失败队列表:
$php artisan queue:failed-table
可在database/migrations里看到一个create_failed_jobs_table.php
更新迁移文件
$php artisan migrate
数据库里多了failed_create_jobs

其它队列系统的依赖扩展包 #
在使用列表里的队列服务前,必须安装以下依赖扩展包:
  • Amazon SQS:aws/aws-sdk-php ~3.0
  • Beanstalkd: pda/pheanstalk ~3.0
  • Redis: predis/predis ~1.0
在composer.json中添加:
  1. "predis/predis":"^1.1",
  1. "aws/aws-sdk-php":"~3.0",
  1. "pda/pheanstalk":"~3.0"
生成器 #
Lumen 中没有可用来生成事件监听器的命令,你可以复制 ExampleJob 文件,这个示例文件提供了基础的类结构,你可以作为参考。基类 Job 已经加载了我们需要的 traits InteractsWithQueue , Queueable , 和 SerializesModels
<?php

namespace App\Jobs;

class ExampleJob extends Job
{
    protected $str;
    /**
     * Create a new job instance.
     * 创建一个新的任务实例
     * @return void
     */
    public function __construct($str)
    {
        //
        $this->str = $str;
    }

    /**
     * Execute the job.
     * 运行任务
     * @return void
     */
    public function handle()
    {
        //
        echo 'hellow '.$this->str;
    }
}

在任意一个控制器中
  1. useApp\Jobs\ExampleJob;
  1. .
  1. .
  1. .
  1. public functionindex()
  1. {
  1.     dispatch(newExampleJob('WJB'));
  1. }

在php—cli模式下 运行队列监听器
$php artisan queue:listen
此时队列已在监听中
再访问该控制器
如下
[2017-03-20 06:31:53] Processing: App\Jobs\ExampleJob
hellow WJB[2017-03-20 06:31:53] Processed:  App\Jobs\ExampleJob

注:

  • queue:work 默认只执行一次队列请求, 当请求执行完成后就终止;
  • queue:listen 监听队列请求, 只要运行着, 就能一直接受请求, 除非手动终止;
  • queue:work --daemon 同 listen 一样, 只要运行着, 就能一直接受请求, 不一样的地方是在这个运行模式下, 当新的请求到来的时候, 不重新加载整个框架, 而是直接 fire 动作.

能看出来, queue:work --daemon 是最高级的, 一般推荐使用这个来处理队列监听.使用 queue:work --daemon , 当更新代码的时候, 需要停止, 然后重新启动, 这样才能把修改的代码应用上.


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值