Этот драйвер для хранения очереди заданий использует AWS SQS.
В приложении должно быть установлено расширение aws/aws-sdk-php
.
Пример настройки:
return [
'bootstrap' => [
'queue', // Компонент регистрирует собственные консольные команды
],
'components' => [
'queue' => [
'class' => \yii\queue\sqs\Queue::class,
'url' => '<sqs url>',
'key' => '<key>',
'secret' => '<secret>',
'region' => '<region>',
],
],
];
Пример настройки для FIFO очередей:
return [
'bootstrap' => [
'queue', // Компонент регистрирует собственные консольные команды
],
'components' => [
'queue' => [
'class' => \yii\queue\sqs\Queue::class,
'url' => '<sqs url>',
'key' => '<key>',
'secret' => '<secret>',
'region' => '<region>',
'messageGroupId' => '<Group ID>',
],
],
];
Идентификатор группы сообщений требуется SQS для очередей FIFO. Вы можете настроить свои собственные или использовать значение "default".
Идентификатор дедупликации генерируется автоматически, поэтому независимо от того, активировали ли вы дедупликацию на основе содержимого в очереди SQS или нет, этот идентификатор будет использоваться.
Для обработки очереди используются консольные команды.
yii queue/listen [timeout]
Команда listen
запускает обработку очереди в режиме демона. Очередь опрашивается непрерывно.
Если добавляются новые задания, то они сразу же извлекаются и выполняются. timeout
- время
ожидания задания из очереди перед следующей итерацией. listen
использует функцию "Long Polling",
которая удерживает соединение с очередью и прослушивает ее на появление новых сообщений.
Важно! Параметрtimeout
для драйвера AWS SQS должен быть в интервале от 0 до 20 секунд.
Способ наиболее эфективен если запускать команду через supervisor или systemd.
yii queue/run
Команда run
в цикле извлекает задания из очереди и выполняет их, пока очередь не опустеет, и
завершает свою работу. Это способ подойдет для обработки очереди заданий через
cron.
Для команд run
и listen
доступны следующие опции:
--verbose
, -v
: состояние обработки заданий выводится в консоль.--isolate
: каждое задание выполняется в отдельном дочернем процессе.--color
: подсветка вывода в режиме --verbose
.yii queue/clear
Команда clear
делает полную очистку очереди.