前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Laravel使用RabbitMQ的方法示例

Laravel使用RabbitMQ的方法示例

作者头像
砸漏
发布2020-10-29 10:12:21
2.2K0
发布2020-10-29 10:12:21
举报
文章被收录于专栏:恩蓝脚本

导语

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 配置,根据情况自行修改
代码语言:javascript
复制
'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 https://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 https://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: https://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 ,并添加以下值

代码语言:javascript
复制
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

以上就是本文的全部内容,希望对大家的学习有所帮助。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器镜像服务
容器镜像服务(Tencent Container Registry,TCR)为您提供安全独享、高性能的容器镜像托管分发服务。您可同时在全球多个地域创建独享实例,以实现容器镜像的就近拉取,降低拉取时间,节约带宽成本。TCR 提供细颗粒度的权限管理及访问控制,保障您的数据安全。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档