Laravel作业队列未使用Redis驱动程序进行处理

时间:2015-12-01 04:50:14

标签: php laravel redis publish-subscribe

我正在创建一个作业,将其推送到自定义队列,然后尝试使用Redis驱动程序在它到达队列时处理该作业,但没有成功:

class MyController extends Controller {
    public function method() {
        $job = (new UpdateLiveThreadJob())->onQueue('live');
        $this->dispatch($job);
    }
}

这是我的队列配置:

    'default' => env('QUEUE_DRIVER'),

    'redis' => [
        'driver' => 'redis',
        'connection' => 'default',
        'queue'  => 'default',
        'expire' => 60,
    ],

这是我的.env文件:

# Drivers (Queues & Broadcasts)
CACHE_DRIVER=file
SESSION_DRIVER=file
QUEUE_DRIVER=redis
BROADCAST_DRIVER=redis

这是我的工作:

class UpdateLiveThreadJob extends Job implements SelfHandling, ShouldQueue
{
    /**
     * Create a new job instance.
     *
     * @return void
     */
    public function __construct()
    {
    }

    /**
     * Execute the job.
     *
     * @return void
     */
    public function handle()
    {
        // Rerender content
        $templatedOutput = view('templates.livethreadcontents')->with([
            'updates' => collect(Redis::lrange('live:updates', 0, -1))->reverse()->map(function($update) {
                return json_decode($update);
            })
        ])->render();

        // Connect to external service

        // Update Thread
    }
}

事实上,我可以更改handle方法,不做任何事情以确保工作中的任何内容都无法实际导致其失败,并且它仍然无法处理:

    /**
     * Execute the job.
     *
     * @return void
     */
    public function handle()
    {
        print_r('test');
    }

使用Redis,我可以看到它被推入队列:

> lrange queues:live 0 -1
> // json encoded job present
> llen queues:live
> // shows there is a job in the queue

然而,据我所知,它实际上从未发生过。观看php artisan queue:listen不显示任何内容(仅显示不相关的事件广播)。这里发生了什么?

1 个答案:

答案 0 :(得分:7)

你还记得跑php artisan queue:listen --queue=live吗?

您需要在运行listen命令时定义队列名称,否则您最终只会收听default队列。

如果你想在生产中运行多个队列和管理事物,你可以使用类似Upstart的东西(与设置Laravel队列没有直接关系,但提供了一个很好的起点)或Supervisor来管理过程。这两种都可以在Forge和Homestead上找到。

最后假设您使用的是Laravel 5,您可能需要考虑运行php artisan queue:work --daemon --queue=live,因为这样可以减少运行工作程序的CPU开销,因为它不会为每个作业重新加载框架。但是,当您为工作部署新代码时,必须记住重新启动工作程序,否则将无法获取任何内容。