Laravel如何通过RabbitMQ实现消息队列?

2026-04-02 05:271阅读0评论SEO资源
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1068个文字,预计阅读时间需要5分钟。

Laravel如何通过RabbitMQ实现消息队列?

:使用 RabbitMQ 驱动 Laravel 队列替代 Redis

导语:RabbitMQ 是一个流行的消息队列系统,它可以帮助我们实现高效的异步处理。本文将介绍如何使用 RabbitMQ 作为 Laravel 队列的驱动,以替代 Redis,并给出在 Laradock 中安装的示例。

内容:以下是如何在 Laradock 中安装并配置 RabbitMQ 作为 Laravel 队列驱动的步骤:

1. 安装 RabbitMQ: 在 Laradock 中,RabbitMQ 已经预装好了。你可以通过以下命令进入 Docker 容器:

bash cd /var/www/laravel docker-compose exec web bash

2. 切换到项目目录: 进入到你的 Laravel 项目目录:

bash cd /var/www/laravel

3. 编辑 `.env` 文件: 打开 `.env` 文件,并找到 `QUEUE_CONNECTION` 和 `QUEUE_CONNECTION` 相关的配置。将它们修改为以下内容:

plaintext QUEUE_CONNECTION=rabbitmq RABBITMQ_HOST=queue RABBITMQ_PORT=5672 RABBITMQ_USERNAME=guest RABBITMQ_PASSWORD=guest

4. 重启 RabbitMQ 服务: 为了使配置生效,需要重启 RabbitMQ 服务:

bash docker-compose restart rabbitmq

Laravel如何通过RabbitMQ实现消息队列?

5. 测试队列: 在 Laravel 控制器或服务中,你可以使用以下代码来测试队列是否正常工作:

php $job=(new SendEmailJob()) ->delay(now()->addSeconds(10));

dispatch($job);

这将创建一个队列任务,10秒后执行。

总结:通过以上步骤,你可以在 Laradock 中成功配置 RabbitMQ 作为 Laravel 队列的驱动,从而替代 Redis。这样,你可以利用 RabbitMQ 的强大功能来提高应用程序的异步处理能力。

导语

RabbitMQ 想必大家都有了解,不做多介绍来。这里实现的是用 RabbitMQ 作为 Larvel 队列的驱动,替代 Redis。下面以 Laradock 中安装示例。

安装

  1. 切换到laradock 目录,将.env 中关于INSTALL_AMQP 的值修改为true
  2. docker-compose stop workspace php-fpm php-worker
  3. docker-compose build workspace php-fpm php-worker rabbitmq
  4. docker-compose up -d workspace php-fpm php-worker rabbitmq

扩展包安装以及配置

  1. 进入到workspace 容器中,在项目目录安装扩展包composer require vladimir-yuldashev/laravel-queue-rabbitmq
  2. 接下来在config/queue.php 文件中connections 添加rabbitmq 配置,根据情况自行修改

'rabbitmq' => [ 'driver' => 'rabbitmq', /* * Set to "horizon" if you wish to use Laravel Horizon. */ 'worker' => env('RABBITMQ_WORKER', 'default'), 'dsn' => env('RABBITMQ_DSN', null), /* * Could be one a class that implements \Interop\Amqp\AmqpConnectionFactory for example: * - \EnqueueAmqpExt\AmqpConnectionFactory if you install enqueue/amqp-ext * - \EnqueueAmqpLib\AmqpConnectionFactory if you install enqueue/amqp-lib * - \EnqueueAmqpBunny\AmqpConnectionFactory if you install enqueue/amqp-bunny */ 'factory_class' => Enqueue\AmqpLib\AmqpConnectionFactory::class, 'host' => env('RABBITMQ_HOST', '127.0.0.1'), 'port' => env('RABBITMQ_PORT', 5672), 'vhost' => env('RABBITMQ_VHOST', '/'), 'login' => env('RABBITMQ_LOGIN', 'guest'), 'password' => env('RABBITMQ_PASSWORD', 'guest'), 'queue' => env('RABBITMQ_QUEUE', 'default'), 'options' => [ 'exchange' => [ 'name' => env('RABBITMQ_EXCHANGE_NAME'), /* * Determine if exchange should be created if it does not exist. */ 'declare' => env('RABBITMQ_EXCHANGE_DECLARE', true), /* * Read more about possible values at www.rabbitmq.com/tutorials/amqp-concepts.html */ 'type' => env('RABBITMQ_EXCHANGE_TYPE', \Interop\Amqp\AmqpTopic::TYPE_DIRECT), 'passive' => env('RABBITMQ_EXCHANGE_PASSIVE', false), 'durable' => env('RABBITMQ_EXCHANGE_DURABLE', true), 'auto_delete' => env('RABBITMQ_EXCHANGE_AUTODELETE', false), 'arguments' => env('RABBITMQ_EXCHANGE_ARGUMENTS'), ], 'queue' => [ /* * Determine if queue should be created if it does not exist. */ 'declare' => env('RABBITMQ_QUEUE_DECLARE', true), /* * Determine if queue should be binded to the exchange created. */ 'bind' => env('RABBITMQ_QUEUE_DECLARE_BIND', true), /* * Read more about possible values at www.rabbitmq.com/tutorials/amqp-concepts.html */ 'passive' => env('RABBITMQ_QUEUE_PASSIVE', false), 'durable' => env('RABBITMQ_QUEUE_DURABLE', true), 'exclusive' => env('RABBITMQ_QUEUE_EXCLUSIVE', false), 'auto_delete' => env('RABBITMQ_QUEUE_AUTODELETE', false), 'arguments' => env('RABBITMQ_QUEUE_ARGUMENTS'), ], ], /* * Determine the number of seconds to sleep if there's an error communicating with rabbitmq * If set to false, it'll throw an exception rather than doing the sleep for X seconds. */ 'sleep_on_error' => env('RABBITMQ_ERROR_SLEEP', 5), /* * Optional SSL params if an SSL connection is used * Using an SSL connection will also require to configure your RabbitMQ to enable SSL. More details can be founds here: www.rabbitmq.com/ssl.html */ 'ssl_params' => [ 'ssl_on' => env('RABBITMQ_SSL', false), 'cafile' => env('RABBITMQ_SSL_CAFILE', null), 'local_cert' => env('RABBITMQ_SSL_LOCALCERT', null), 'local_key' => env('RABBITMQ_SSL_LOCALKEY', null), 'verify_peer' => env('RABBITMQ_SSL_VERIFY_PEER', true), 'passphrase' => env('RABBITMQ_SSL_PASSPHRASE', null), ], ],

在.env 中修改QUEUE_CONNECTION 为rabbitmq ,并添加以下值

RABBITMQ_WORKER=horizon RABBITMQ_HOST=rabbitmq RABBITMQ_PORT=5672 RABBITMQ_LOGIN=guest RABBITMQ_PASSWORD=guest RABBITMQ_QUEUE=default

有两个值说明一下,因为是在 Laradock 中,所以RABBITMQ_HOST 设置为rabbitmq ;如果之前使用了Laravel Horizon,那么RABBITMQ_WORKER 的设置为horizon 就可以了。

参考资料:laravel-queue-rabbitmq

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。

本文共计1068个文字,预计阅读时间需要5分钟。

Laravel如何通过RabbitMQ实现消息队列?

:使用 RabbitMQ 驱动 Laravel 队列替代 Redis

导语:RabbitMQ 是一个流行的消息队列系统,它可以帮助我们实现高效的异步处理。本文将介绍如何使用 RabbitMQ 作为 Laravel 队列的驱动,以替代 Redis,并给出在 Laradock 中安装的示例。

内容:以下是如何在 Laradock 中安装并配置 RabbitMQ 作为 Laravel 队列驱动的步骤:

1. 安装 RabbitMQ: 在 Laradock 中,RabbitMQ 已经预装好了。你可以通过以下命令进入 Docker 容器:

bash cd /var/www/laravel docker-compose exec web bash

2. 切换到项目目录: 进入到你的 Laravel 项目目录:

bash cd /var/www/laravel

3. 编辑 `.env` 文件: 打开 `.env` 文件,并找到 `QUEUE_CONNECTION` 和 `QUEUE_CONNECTION` 相关的配置。将它们修改为以下内容:

plaintext QUEUE_CONNECTION=rabbitmq RABBITMQ_HOST=queue RABBITMQ_PORT=5672 RABBITMQ_USERNAME=guest RABBITMQ_PASSWORD=guest

4. 重启 RabbitMQ 服务: 为了使配置生效,需要重启 RabbitMQ 服务:

bash docker-compose restart rabbitmq

Laravel如何通过RabbitMQ实现消息队列?

5. 测试队列: 在 Laravel 控制器或服务中,你可以使用以下代码来测试队列是否正常工作:

php $job=(new SendEmailJob()) ->delay(now()->addSeconds(10));

dispatch($job);

这将创建一个队列任务,10秒后执行。

总结:通过以上步骤,你可以在 Laradock 中成功配置 RabbitMQ 作为 Laravel 队列的驱动,从而替代 Redis。这样,你可以利用 RabbitMQ 的强大功能来提高应用程序的异步处理能力。

导语

RabbitMQ 想必大家都有了解,不做多介绍来。这里实现的是用 RabbitMQ 作为 Larvel 队列的驱动,替代 Redis。下面以 Laradock 中安装示例。

安装

  1. 切换到laradock 目录,将.env 中关于INSTALL_AMQP 的值修改为true
  2. docker-compose stop workspace php-fpm php-worker
  3. docker-compose build workspace php-fpm php-worker rabbitmq
  4. docker-compose up -d workspace php-fpm php-worker rabbitmq

扩展包安装以及配置

  1. 进入到workspace 容器中,在项目目录安装扩展包composer require vladimir-yuldashev/laravel-queue-rabbitmq
  2. 接下来在config/queue.php 文件中connections 添加rabbitmq 配置,根据情况自行修改

'rabbitmq' => [ 'driver' => 'rabbitmq', /* * Set to "horizon" if you wish to use Laravel Horizon. */ 'worker' => env('RABBITMQ_WORKER', 'default'), 'dsn' => env('RABBITMQ_DSN', null), /* * Could be one a class that implements \Interop\Amqp\AmqpConnectionFactory for example: * - \EnqueueAmqpExt\AmqpConnectionFactory if you install enqueue/amqp-ext * - \EnqueueAmqpLib\AmqpConnectionFactory if you install enqueue/amqp-lib * - \EnqueueAmqpBunny\AmqpConnectionFactory if you install enqueue/amqp-bunny */ 'factory_class' => Enqueue\AmqpLib\AmqpConnectionFactory::class, 'host' => env('RABBITMQ_HOST', '127.0.0.1'), 'port' => env('RABBITMQ_PORT', 5672), 'vhost' => env('RABBITMQ_VHOST', '/'), 'login' => env('RABBITMQ_LOGIN', 'guest'), 'password' => env('RABBITMQ_PASSWORD', 'guest'), 'queue' => env('RABBITMQ_QUEUE', 'default'), 'options' => [ 'exchange' => [ 'name' => env('RABBITMQ_EXCHANGE_NAME'), /* * Determine if exchange should be created if it does not exist. */ 'declare' => env('RABBITMQ_EXCHANGE_DECLARE', true), /* * Read more about possible values at www.rabbitmq.com/tutorials/amqp-concepts.html */ 'type' => env('RABBITMQ_EXCHANGE_TYPE', \Interop\Amqp\AmqpTopic::TYPE_DIRECT), 'passive' => env('RABBITMQ_EXCHANGE_PASSIVE', false), 'durable' => env('RABBITMQ_EXCHANGE_DURABLE', true), 'auto_delete' => env('RABBITMQ_EXCHANGE_AUTODELETE', false), 'arguments' => env('RABBITMQ_EXCHANGE_ARGUMENTS'), ], 'queue' => [ /* * Determine if queue should be created if it does not exist. */ 'declare' => env('RABBITMQ_QUEUE_DECLARE', true), /* * Determine if queue should be binded to the exchange created. */ 'bind' => env('RABBITMQ_QUEUE_DECLARE_BIND', true), /* * Read more about possible values at www.rabbitmq.com/tutorials/amqp-concepts.html */ 'passive' => env('RABBITMQ_QUEUE_PASSIVE', false), 'durable' => env('RABBITMQ_QUEUE_DURABLE', true), 'exclusive' => env('RABBITMQ_QUEUE_EXCLUSIVE', false), 'auto_delete' => env('RABBITMQ_QUEUE_AUTODELETE', false), 'arguments' => env('RABBITMQ_QUEUE_ARGUMENTS'), ], ], /* * Determine the number of seconds to sleep if there's an error communicating with rabbitmq * If set to false, it'll throw an exception rather than doing the sleep for X seconds. */ 'sleep_on_error' => env('RABBITMQ_ERROR_SLEEP', 5), /* * Optional SSL params if an SSL connection is used * Using an SSL connection will also require to configure your RabbitMQ to enable SSL. More details can be founds here: www.rabbitmq.com/ssl.html */ 'ssl_params' => [ 'ssl_on' => env('RABBITMQ_SSL', false), 'cafile' => env('RABBITMQ_SSL_CAFILE', null), 'local_cert' => env('RABBITMQ_SSL_LOCALCERT', null), 'local_key' => env('RABBITMQ_SSL_LOCALKEY', null), 'verify_peer' => env('RABBITMQ_SSL_VERIFY_PEER', true), 'passphrase' => env('RABBITMQ_SSL_PASSPHRASE', null), ], ],

在.env 中修改QUEUE_CONNECTION 为rabbitmq ,并添加以下值

RABBITMQ_WORKER=horizon RABBITMQ_HOST=rabbitmq RABBITMQ_PORT=5672 RABBITMQ_LOGIN=guest RABBITMQ_PASSWORD=guest RABBITMQ_QUEUE=default

有两个值说明一下,因为是在 Laradock 中,所以RABBITMQ_HOST 设置为rabbitmq ;如果之前使用了Laravel Horizon,那么RABBITMQ_WORKER 的设置为horizon 就可以了。

参考资料:laravel-queue-rabbitmq

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。