当前位置:首页 > PHP教程 > php高级应用 > 列表

PHP使用ActiveMQ实现消息队列的方法详解

发布:smiling 来源: PHP粉丝网  添加日期:2021-11-24 20:04:04 浏览: 评论:0 

这篇文章主要介绍了PHP使用ActiveMQ实现消息队列的方法,结合实例形式详细分析了PHP使用ActiveMQ实现消息队列具体步骤、相关操作技巧与注意事项,需要的朋友可以参考下。

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

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

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

今天

ActiveMQ PHP消息队列

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

下载:

composer require fusesource/stomp-php:2.0.*

然后新建test.php:

  1. require __DIR__.'/vendor/autoload.php'//引入自动加载的文件 
  2.  
  3. $connect = new \FuseSource\Stomp\Stomp('tcp://10.211.55.13/:61613'); 
  4. $connect->connect(); 
  5.  
  6. $userId = 1001; 
  7. $result = $connect->send('email',$userId); //比如发邮件 
  8. var_dump($result); 

ActiveMQ PHP消息队列

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

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

ActiveMQ PHP消息队列

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

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

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

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

ActiveMQ PHP消息队列

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

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

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

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

前面我们完成了『发送』

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

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

  1.  
  2. require __DIR__.'/vendor/autoload.php'//引入自动加载的文件 
  3.  
  4. $connect = new \FuseSource\Stomp\Stomp('tcp://10.211.55.13/:61613'); 
  5. $connect->connect(); 
  6.  
  7. //订阅队列消息 
  8. $connect->subscribe('email'); 
  9.  
  10. if ($connect->hasFrameToRead()){ 
  11.   $frame = $connect->readFrame(); 
  12.   print_r($frame); 

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

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

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

  1. FuseSource\Stomp\Frame Object 
  2.   [command] => MESSAGE 
  3.   [headers] => Array 
  4.     ( 
  5.       [expires] => 0 
  6.       [destination] => /queue/email 
  7.       [priority] => 4 
  8.       [message-id] => ID:localhost.localdomain-38488-1488196907415-3:2:-1:1:1 
  9.       [timestamp] => 1489477647931 
  10.     ) 
  11.  
  12.   [body] => {"id":1001,"email":"110@qq.com","content":"test"

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

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

  1. do
  2.   if ($connect->hasFrameToRead()){ 
  3.     $frame = $connect->readFrame(); 
  4.     print_r($frame->body); 
  5.   } 
  6. while (true); 

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

  1. if ($connect->hasFrameToRead()){ 
  2.   $frame = $connect->readFrame(); 
  3.   //print_r($frame->body); 
  4.  
  5.   //做业务逻辑 
  6.   //具体发送邮件的业务 
  7.   //send email 
  8.  
  9.   //最后通知mq,我们已经处理了该条消息 
  10.   $connect->ack($frame); 

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

  1. do
  2.   //会等待,直到有可用消息,才执行后面代码 
  3.   if ($connect->hasFrameToRead()){ 
  4.     $frame = $connect->readFrame(); 
  5.     //print_r($frame->body); 
  6.  
  7.     //做业务逻辑 
  8.     //具体发送邮件的业务 
  9.     //send email 
  10.     sleep(2); //模拟延时 
  11.  
  12.     //最后通知mq,我们已经处理了该条消息 
  13.     $connect->ack($frame); 
  14.   } 
  15.  
  16.   //控制循环 
  17.   $next = true; 
  18.   if (file_exists(__DIR__.'/stop')){ 
  19.     //如果有名为stop的一个文件 
  20.     //就不循环了 
  21.     $next = false; 
  22.   } 
  23. while ($next);

Tags: ActiveMQ PHP消息队列

分享到: