jaslin / yii2-amqp
Yii 2 扩展,用于通过 AMQP 与 RabbitMQ 服务器通信。基于 videlalvaro/php-amqplib。
v1.0.0
2014-07-24 04:42 UTC
Requires
- php: >=5.3.0
- videlalvaro/php-amqplib: 2.4.0
- webtoucher/yii2-commands: *
This package is not auto-updated.
Last update: 2024-10-02 10:30:02 UTC
README
用于与 RabbitMQ 服务器通信的 AMQP 扩展。基于 videlalvaro/php-amqplib。
安装
安装此扩展的首选方式是通过 composer。
运行以下命令之一:
$ php composer.phar require webtoucher/yii2-amqp "*"
或者
"webtoucher/yii2-amqp": "*"
将以下内容添加到你的 composer.json
文件的 require
部分:
在控制台配置中添加以下内容
return [ ... 'components' => [ ... 'amqp' => [ 'class' => 'webtoucher\amqp\components\Amqp', 'host' => '127.0.0.1', 'port' => 5672, 'user' => 'your_login', 'password' => 'your_password', 'vhost' => '/', ], ... ], ... 'controllerMap' => [ ... 'rabbit' => [ 'class' => 'webtoucher\amqp\controllers\AmqpListenerController', 'interpreters' => [ 'my-exchange' => 'app\components\RabbitInterpreter', // interpreters for each exchange ], 'exchange' => 'my-exchange', // default exchange ], ... ], ... ];
添加消息解释器类 @app/components/RabbitInterpreter
,并使用你的处理器处理不同的路由键
<?php namespace app\components; use webtoucher\amqp\components\AmqpInterpreter; class RabbitInterpreter extends AmqpInterpreter { /** * Interprets AMQP message with routing key 'hello_world'. * * @param array $message */ public function readHelloWorld($message) { // todo: write message handler $this->log(print_r($message, true)); } }
用法
只需运行以下命令
$ php yii rabbit
以监听默认交换机上的任何路由键的主题
$ php yii rabbit my_routing_key
以监听具有一个路由键的主题。
运行以下命令
$ php yii rabbit my_routing_key direct --exchange=my_exchange
以监听所选交换机的直接消息。
运行以下命令
$ php yii rabbit --exchange=my_exchange --queue=queue1
以监听所选交换机上绑定队列1的消息
此外,您还可以根据需要创建控制器。只需使用 webtoucher\amqp\controllers\AmqpConsoleController
替代 yii\web\Controller
作为您的 Web 控制器类,并使用 webtoucher\amqp\controllers\AmqpConsoleController
替代 yii\console\Controller
作为您的控制台控制器类。AMQP 连接将可通过属性 connection
获取。AMQP 通道将可通过属性 channel
获取。