当前位置:首页 > CMS教程 > 其它CMS > 列表

Laravel使用RabbitMQ的方法示例

发布:smiling 来源: PHP粉丝网  添加日期:2021-11-26 11:35:16 浏览: 评论:0 

这篇文章主要介绍了Laravel使用RabbitMQ的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。

导语

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

安装

切换到 laradock 目录,将 .env 中关于 INSTALL_AMQP 的值修改为 true

docker-compose stop workspace php-fpm php-worker

docker-compose build workspace php-fpm php-worker rabbitmq

docker-compose up -d workspace php-fpm php-worker rabbitmq

扩展包安装以及配置

进入到 workspace 容器中,在项目目录安装扩展包 composer require vladimir-yuldashev/laravel-queue-rabbitmq

接下来在 config/queue.php 文件中 connections 添加 rabbitmq 配置,根据情况自行修改

  1. 'rabbitmq' => [ 
  2.  
  3.   'driver' => 'rabbitmq'
  4.  
  5.   /* 
  6.    * Set to "horizon" if you wish to use Laravel Horizon. 
  7.    */ 
  8.   'worker' => env('RABBITMQ_WORKER''default'), 
  9.  
  10.   'dsn' => env('RABBITMQ_DSN', null), 
  11.  
  12.   /* 
  13.    * Could be one a class that implements \Interop\Amqp\AmqpConnectionFactory for example: 
  14.    * - \EnqueueAmqpExt\AmqpConnectionFactory if you install enqueue/amqp-ext 
  15.    * - \EnqueueAmqpLib\AmqpConnectionFactory if you install enqueue/amqp-lib 
  16.    * - \EnqueueAmqpBunny\AmqpConnectionFactory if you install enqueue/amqp-bunny 
  17.    */ 
  18.  
  19.   'factory_class' => Enqueue\AmqpLib\AmqpConnectionFactory::class
  20.  
  21.   'host' => env('RABBITMQ_HOST''127.0.0.1'), 
  22.   'port' => env('RABBITMQ_PORT', 5672), 
  23.  
  24.   'vhost' => env('RABBITMQ_VHOST''/'), 
  25.   'login' => env('RABBITMQ_LOGIN''guest'), 
  26.   'password' => env('RABBITMQ_PASSWORD''guest'), 
  27.  
  28.   'queue' => env('RABBITMQ_QUEUE''default'), 
  29.  
  30.   'options' => [ 
  31.  
  32.     'exchange' => [ 
  33.  
  34.       'name' => env('RABBITMQ_EXCHANGE_NAME'), 
  35.  
  36.       /* 
  37.        * Determine if exchange should be created if it does not exist. 
  38.        */ 
  39.  
  40.       'declare' => env('RABBITMQ_EXCHANGE_DECLARE', true), 
  41.  
  42.       /* 
  43.        * Read more about possible values at https://www.rabbitmq.com/tutorials/amqp-concepts.html 
  44.        */ 
  45.  
  46.       'type' => env('RABBITMQ_EXCHANGE_TYPE', \Interop\Amqp\AmqpTopic::TYPE_DIRECT), 
  47.       'passive' => env('RABBITMQ_EXCHANGE_PASSIVE', false), 
  48.       'durable' => env('RABBITMQ_EXCHANGE_DURABLE', true), 
  49.       'auto_delete' => env('RABBITMQ_EXCHANGE_AUTODELETE', false), 
  50.       'arguments' => env('RABBITMQ_EXCHANGE_ARGUMENTS'), 
  51.     ], 
  52.  
  53.     'queue' => [ 
  54.  
  55.       /* 
  56.        * Determine if queue should be created if it does not exist. 
  57.        */ 
  58.  
  59.       'declare' => env('RABBITMQ_QUEUE_DECLARE', true), 
  60.  
  61.       /* 
  62.        * Determine if queue should be binded to the exchange created. 
  63.        */ 
  64.  
  65.       'bind' => env('RABBITMQ_QUEUE_DECLARE_BIND', true), 
  66.  
  67.       /* 
  68.        * Read more about possible values at https://www.rabbitmq.com/tutorials/amqp-concepts.html 
  69.        */ 
  70.  
  71.       'passive' => env('RABBITMQ_QUEUE_PASSIVE', false), 
  72.       'durable' => env('RABBITMQ_QUEUE_DURABLE', true), 
  73.       'exclusive' => env('RABBITMQ_QUEUE_EXCLUSIVE', false), 
  74.       'auto_delete' => env('RABBITMQ_QUEUE_AUTODELETE', false), 
  75.       'arguments' => env('RABBITMQ_QUEUE_ARGUMENTS'), 
  76.     ], 
  77.   ], 
  78.  
  79.   /* 
  80.    * Determine the number of seconds to sleep if there's an error communicating with rabbitmq 
  81.    * If set to false, it'll throw an exception rather than doing the sleep for X seconds. 
  82.    */ 
  83.  
  84.   'sleep_on_error' => env('RABBITMQ_ERROR_SLEEP', 5), 
  85.  
  86.   /* 
  87.    * Optional SSL params if an SSL connection is used 
  88.    * 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 
  89.    */ 
  90.  
  91.   'ssl_params' => [ 
  92.     'ssl_on' => env('RABBITMQ_SSL', false), 
  93.     'cafile' => env('RABBITMQ_SSL_CAFILE', null), 
  94.     'local_cert' => env('RABBITMQ_SSL_LOCALCERT', null), 
  95.     'local_key' => env('RABBITMQ_SSL_LOCALKEY', null), 
  96.     'verify_peer' => env('RABBITMQ_SSL_VERIFY_PEER', true), 
  97.     'passphrase' => env('RABBITMQ_SSL_PASSPHRASE', null), 
  98.   ], 
  99.  
  100. ], 

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

  1. RABBITMQ_WORKER=horizon 
  2. RABBITMQ_HOST=rabbitmq 
  3. RABBITMQ_PORT=5672 
  4. RABBITMQ_LOGIN=guest 
  5. RABBITMQ_PASSWORD=guest 
  6. RABBITMQ_QUEUE=default 

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

参考资料:laravel-queue-rabbitmq 

Tags: Laravel RabbitMQ

分享到: