activemq php java_PHP使用ActiveMQ实现消息队列的方法详解

本文实例讲述了PHP使用ActiveMQ实现消息队列的方法。分享给大家供大家参考,具体如下:

前面我们已经学了如何部署ActiveMQ,

我们知道通过ActiveMQ的一个管理后台可以查看任务队列。

今天

b700d3dfd0c319daffeb893a6e319321.png

用PHP来操作ActiveMQ,我们可以借助一个第三方扩展。

下载:

composer require fusesource/stomp-php:2.0.*

然后新建test.php:

require __DIR__.'/vendor/autoload.php'; //引入自动加载的文件

$connect = new \FuseSource\Stomp\Stomp('tcp://10.211.55.13/:61613');

$connect->connect();

$userId = 1001;

$result = $connect->send('email',$userId); //比如发邮件

var_dump($result);

94faf6ef25835e034cf37517f68420dc.png

发送消息成功,打印bool(true)

我们在ActiveMQ自带的管理后台查看,确实有一个名为”email”的队列。

f98f4affe65e45c06be40ac6bf20b9a8.png

上面我们发送的一个id,我们还可以发送json数据。

$data = array('id'=>1001,'email'=>'110@qq.com','content'=>'test');

$result = $connect->send('email',json_encode($data));

我们在MQ后台可以查看消息详细

ca17ced45cada4b0608ba24a28b79cdb.png

上面的代码到这里,还不够完美。如果我们服务器重启了activemq,没有处理的消息会丢失。

这个时候我们需要用到send()方法的第三个参数。

//消息持久化 persistent为true,字符串的'true'

$result = $connect->send('email',json_encode($data),array('persistent'=>'true'));

前面我们完成了『发送』

给mq服务器发送消息(email消息)。

那么在mq的队列中的任务,又是怎么处理的呢?

require __DIR__.'/vendor/autoload.php'; //引入自动加载的文件

$connect = new \FuseSource\Stomp\Stomp('tcp://10.211.55.13/:61613');

$connect->connect();

//订阅队列消息

$connect->subscribe('email');

if ($connect->hasFrameToRead()){

$frame = $connect->readFrame();

print_r($frame);

}

在mq服务端,订阅(监听)队列消息。

在服务端是命令行下执行:php mqServer.php

如果有没有处理的消息,可以读取出来,打印结果如下:

FuseSource\Stomp\Frame Object

(

[command] => MESSAGE

[headers] => Array

(

[expires] => 0

[destination] => /queue/email

[priority] => 4

[message-id] => ID:localhost.localdomain-38488-1488196907415-3:2:-1:1:1

[timestamp] => 1489477647931

)

[body] => {"id":1001,"email":"110@qq.com","content":"test"}

)

body就把我们发送的内容读取出来了。

我们循环读取(死循环)一直等待新消息:

do{

if ($connect->hasFrameToRead()){

$frame = $connect->readFrame();

print_r($frame->body);

}

} while (true);

处理消息之后(在发送邮件等业务完成之后),要通知mq我处理了该条消息了

if ($connect->hasFrameToRead()){

$frame = $connect->readFrame();

//print_r($frame->body);

//做业务逻辑

//具体发送邮件的业务

//send email

//最后通知mq,我们已经处理了该条消息

$connect->ack($frame);

}

我们还可以在优化一下代码,解决死循环,控制循环(这里是一种方案演示)

do{

//会等待,直到有可用消息,才执行后面代码

if ($connect->hasFrameToRead()){

$frame = $connect->readFrame();

//print_r($frame->body);

//做业务逻辑

//具体发送邮件的业务

//send email

sleep(2); //模拟延时

//最后通知mq,我们已经处理了该条消息

$connect->ack($frame);

}

//控制循环

$next = true;

if (file_exists(__DIR__.'/stop')){

//如果有名为stop的一个文件

//就不循环了

$next = false;

}

} while ($next);

希望本文所述对大家PHP程序设计有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值