Драйвер для Redis

Этот драйвер для хранения очереди заданий использует Redis.

В приложении должно быть установлено расширение yiisoft/yii2-redis.

Пример настройки:

return [
    'bootstrap' => [
        'queue', // Компонент регистрирует свои консольные команды 
    ],
    'components' => [
        'queue' => [
            'class' => \zhuravljov\yii\queue\redis\Queue::class,
            'redis' => 'redis', // ID подключения
            'channel' => 'queue', // Ключ канала очереди
        ],
    ],
];

Консоль

Для обратки очереди используются консольные команды.

yii queue/run

Команда run в цикле извлекает задания из очереди и выполняет их, пока очередь не опустеет, и завершает свою работу. Это способ подойдет для обработки очереди заданий через cron.

yii queue/listen

Команда listen запускает обработку очереди в режиме демона. Очередь опрашивается непрерывно. Если добавляются новые задания, то они сразу же извлекаются и выполняются. Способ наиболее эфективен если запускать команду через демон-супервизор, например supervisord.

Для команд run и listen доступны следующие опции:

  • --verbose, -v: состояние обработки заданий выводится в консоль.
  • --isolate: каждое задание выполняется в отдельном дочернем процессе.
  • --color: подсветка вывода в режиме --verbose.
yii queue/info

Команда info выводит информацию о состоянии очереди.