Обработка очереди Laravel Horizon, но не получение ожидаемого результата - PullRequest
0 голосов
/ 24 января 2019

Я использую Laravel Horizon (Redis), и я не могу заставить свои задания правильно обрабатывать.

Я вижу, когда я звоню на свой маршрут, который я получаю:

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

В журнале и на панели управления Horizon все выглядит нормально.

Однако, похоже, моя работа не запускает код.


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 не обновляется с помощью моих операторов журнала, и моя база данных остается пустой из функции 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'
    ]);
}

1 Ответ

0 голосов
/ 24 января 2019

Вы определили заполнение в вашей сущности Посетитель? в большинстве случаев это происходит только в том случае, если вы не определили объект, который можно заполнить.

...