Очередь создана, но никогда не выполняется - PullRequest
0 голосов
/ 27 октября 2019

Я пытаюсь вызвать push-уведомления и электронные письма на фоне моего Lumen API. Я создал класс WarningUser, который создает обе очереди:

<?php

namespace App\Utils;

use App\Jobs\ProcessNotification;
use App\Mail\AllMail;
use Illuminate\Support\Facades\Mail;

class WarningUser
{

  public static function send($user, $message, $url, $data = [])
  {
    $url = env('APP_URL_FRONT') . $url;
    dispatch(new ProcessNotification($user, $data, $message, $url));

    $emailData = EmailTexts::texts('pt', $data)[$message];
    Mail::to($user->email)->queue(new AllMail($emailData['title'], $emailData['content']));

    return true;
  }
}

Сначала у нас есть задание ProcessNotification, которое подключается к Firebase и отправляет уведомление:

<?php

namespace App\Jobs;

use Kreait\Firebase\Factory;
use Kreait\Firebase\Messaging\Notification;
use Kreait\Firebase\Messaging\CloudMessage;

class ProcessNotification extends Job
{
    protected $user = null;
    protected $data = null;
    protected $message = null;
    protected $url = null;

    public function __construct($user, $data, $message, $url)
    {
        $this->user = $user;
        $this->data = $data;
        $this->message = $message;
        $this->url = $url;
    }

    public function handle()
    {
        if (\is_string($this->user->token) and $this->user->token !== '') {
            $messaging = (new Factory())
                ->withServiceAccount(__DIR__.'/../../private-key.json')
                ->createMessaging();

            $notificationData = NotificationTexts::texts('pt', $this->data)[$this->message];
            $messageAlert = CloudMessage::withTarget('token', $this->user->token)
                ->withNotification(Notification::create($notificationData['title'], $notificationData['content']))
            ->withData([ 'url' => $this->url ]);

            $messaging->send($messageAlert);
        }
    }
}

И, наконец, AllMail, который отправляетпростая электронная почта:

<?php

namespace App\Mail;

use Illuminate\Bus\Queueable;
use Illuminate\Mail\Mailable;
use Illuminate\Queue\SerializesModels;
use Illuminate\Contracts\Queue\ShouldQueue;

class AllMail extends Mailable implements ShouldQueue
{
    use Queueable, SerializesModels;
    protected $title;
    protected $body;

    public function __construct($title, $body)
    {
        $this->title = $title;
        $this->body = $body;
    }

    public function build()
    {

        return $this
            ->subject($this->title)
            ->view('email')
        ->with([
            'title' => $this->title,
            'body' => $this->body
        ]);
    }
}

Я протестировал оба кода без использования очередей, и они работают, но когда я ставлю очередь, она перестает работать. Процессы записаны в моей базе данных (mongodb):

enter image description here

Но очередь никогда не обрабатывается, я пытался выполнить php artisan queue: work и php artisan queue: listen, но ни один из вариантов не работает.

Очередь никогда не пытается обрабатываться, и она не попадает в таблицу failed_jobs 1022 *

My config / queue.php следующим образом. А у меня .env с QUEUE_CONNECTION = database

<?php

return [
    'default' => env('QUEUE_CONNECTION', 'database'),
    'connections' => [
        'sync' => [
            'driver' => 'sync',
        ],

        'database' => [
            'driver' => 'database',
            'table' => 'jobs',
            'queue' => 'default',
            'retry_after' => 90,
        ],

        'beanstalkd' => [
            'driver' => 'beanstalkd',
            'host' => 'localhost',
            'queue' => 'default',
            'retry_after' => 90,
            'block_for' => 0,
        ],

        'sqs' => [
            'driver' => 'sqs',
            'key' => env('AWS_ACCESS_KEY_ID'),
            'secret' => env('AWS_SECRET_ACCESS_KEY'),
            'prefix' => env('SQS_PREFIX', 'https://sqs.us-east-1.amazonaws.com/your-account-id'),
            'queue' => env('SQS_QUEUE', 'your-queue-name'),
            'region' => env('AWS_DEFAULT_REGION', 'us-east-1'),
        ],

        'redis' => [
            'driver' => 'redis',
            'connection' => 'default',
            'queue' => env('REDIS_QUEUE', 'default'),
            'retry_after' => 90,
            'block_for' => null,
        ],

    ],
    'failed' => [
        'driver' => env('QUEUE_FAILED_DRIVER', 'database'),
        'database' => env('DB_CONNECTION', 'mongodb'),
        'table' => 'failed_jobs',
    ],
];

Может кто-нибудь мне помочь? Я больше не знаю, в чем может быть ошибка.

PS: ошибка браузера или консоли никогда не отображается

1 Ответ

0 голосов
/ 27 октября 2019

Мне удалось решить, для Mongo нам нужно использовать еще несколько настроек:

Соединение в queue.php должно быть:

'connections' => [
    'database' => [
        'driver' => 'mongodb',
        'table'  => 'jobs',
        'queue'  => 'default',
        'expire' => 60,
    ],
...

И нам нужно зарегистрировать провайдера пакетов. который работает с монго:

Jenssegers\Mongodb\MongodbQueueServiceProvider::class,

...