php rabbitmq 邮件发送,用 PHP 收发 RabbitMQ 消息

AMQP

扩展的安装参照《给

PHP

安装

amqp

扩展》

消费者:接收消息

逻辑:

创建连接

-->

创建

channel-->

创建交换机

-->

创建队列

-->

绑定交换机

/

队列

/

路由键

-->

接收

消息

/*************************************

* PHP amqp(RabbitMQ) Demo - consumer

* Author: Linvo

* Date: 2012/7/30

*************************************/

//

配置信息

$conn_args = array(

'host' => '192.168.1.93',

'port' => '5672',

'login' => 'guest',

'password' => 'guest',

'vhost'=>'/'

);

$e_name = 'e_linvo'; //

交换机名

$q_name = 'q_linvo'; //

队列名

$k_route = 'key_1'; //

路由

key

//

创建连接和

channel

$conn = new AMQPConnection($conn_args);

if (!$conn->connect()) {

die("Cannot connect to the broker!\n");

}

$channel = new AMQPChannel($conn);

//

创建交换机

$ex = new AMQPExchange($channel);

$ex->setName($e_name);

$ex->setType(AMQP_EX_TYPE_DIRECT); //direct

类型

$ex->setFlags(AMQP_DURABLE); //

持久化

echo "Exchange Status:".$ex->declare()."\n";

//

创建队列

$q = new AMQPQueue($channel);

$q->setName($q_name);

$q->setFlags(AMQP_DURABLE); //

持久化

echo "Message Total:".$q->declare()."\n";

//

绑定交换机与队列,并指定路由键

echo 'Queue Bind: '.$q->bind($e_name, $k_route)."\n";

//

阻塞模式接收消息

echo "Message:\n";

while(True){

$q->consume('processMessage');

//$q->consume('processMessage', AMQP_AUTOACK); //

自动

ACK

应答

}

$conn->disconnect();

/**

*

消费回调函数

*

处理消息

*/

function processMessage($envelope, $queue) {

$msg = $envelope->getBody();

echo $msg."\n"; //

处理消息

$queue->ack($envelope->getDeliveryTag()); //

手动发送

ACK

应答

}

生产者:发送消息

逻辑:创建连接

-->

创建

channel-->

创建交换机对象

-->

发送消息

/*************************************

* PHP amqp(RabbitMQ) Demo - publisher

* Author: Linvo

* Date: 2012/7/30

*************************************/

//

配置信息

$conn_args = array(

'host' => '192.168.1.93',

'port' => '5672',

'login' => 'guest',

'password' => 'guest',

'vhost'=>'/'

);

$e_name = 'e_linvo'; //

交换机名

//$q_name = 'q_linvo'; //

无需队列名

$k_route = 'key_1'; //

路由

key

//

创建连接和

channel

$conn = new AMQPConnection($conn_args);

if (!$conn->connect()) {

die("Cannot connect to the broker!\n");

}

$channel = new AMQPChannel($conn);

//

消息内容

$message = "TEST MESSAGE!

测试消息!

";

//

创建交换机对象

$ex = new AMQPExchange($channel);

$ex->setName($e_name);

//

发送消息

//$channel->startTransaction(); //

开始事务

for($i=0; $i<5; ++$i){

echo "Send Message:".$ex->publish($message, $k_route)."\n";

}

//$channel->commitTransaction(); //

提交事务

$conn->disconnect();

需要注意的地方是:

queue

对象有两个方法可用于取消息:

consume

get

前者是阻塞的,无消息时会被挂起,适合循环中使用;

后者则是非阻塞的,取消息时有则取,无则返回

false

测试截图:

运行消费者,收消息:

运行生产者,发消息:

消费者接收到消息:

3cbf9bacbcd057e9d70d65a1be174cb9.png

3cbf9bacbcd057e9d70d65a1be174cb9.png

571080b900b0e30c7d1cc5a9cc684700.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值