我正在使用Laravel Horizo​​n(Redis),但似乎无法正确处理我的工作。

我可以看到拨打路线的电话:

[2019-01-24 12:03:47][7] Processing: App\Jobs\CheckInVisitor
[2019-01-24 12:03:47][7] Processed:  App\Jobs\CheckInVisitor

在日志中,它在Horizo​​n Dashboard上看起来不错。

但是我的工作似乎没有运行代码。

CheckInVisitor.php

namespace App\Jobs;

use Illuminate\Bus\Queueable;
use Illuminate\Queue\SerializesModels;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Http\Request;
use App\Visitor;
use Illuminate\Support\Facades\Log;

class CheckInVisitor implements ShouldQueue
{
    use Dispatchable, InteractsWithQueue, Queueable;

    protected $visitor;

    public function __construct($visitor)
    {
        $this->visitor = $visitor;
    }

    public function handle()
    {

        Log::info('Creating Visitor');

        $visitor = Visitor::create([
            'forename' => $this->visitor['forename'],
            'surname' => $this->visitor['surname'],
            'email' => $this->visitor['email'],
        ]);

        Log::info('Visitor Created');
        Log::info($visitor);
    }
}
laravel.log似乎没有随Log语句更新,并且Model::create函数的数据库仍然为空,我尝试首先使用$visitor = new Visitor();创建实例,然后使用$visitor->fill()无效。

地平线仪表板显示作业已成功完成。日志文件中没有错误。

VisitorController.php
public function store(Request $request) {
    $array = $request->all();

    CheckInVisitor::dispatch($array['visitor']);

    return response()->json([
        'messsage' => 'received'
    ]);
}

最佳答案

您是否在实体访问者中定义了可填充项?在大多数情况下,仅当您未定义可填充实体时,它才会发生。

关于php - Laravel Horizo​​n队列处理,但未收到预期结果,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/54346490/

10-10 00:47