本文實例講述了PHP使用ActiveMQ實現消息隊列的方法。分享給大家供大家參考,具體如下:
前面我們已經學了如何部署ActiveMQ,
我們知道通過ActiveMQ的一個管理后臺可以查看任務隊列。
今天
用PHP來操作ActiveMQ,我們可以借助一個第三方擴展。
下載:
composer require fusesource/stomp-php:2.0.*
然后新建test.php:
?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); //比如發(fā)郵件
var_dump($result);
發(fā)送消息成功,打印bool(true)
我們在ActiveMQ自帶的管理后臺查看,確實有一個名為”email”的隊列。
上面我們發(fā)送的一個id,我們還可以發(fā)送json數據。
$data = array('id'=>1001,'email'=>'110@qq.com','content'=>'test');
$result = $connect->send('email',json_encode($data));
我們在MQ后臺可以查看消息詳細
上面的代碼到這里,還不夠完美。如果我們服務器重啟了activemq,沒有處理的消息會丟失。
這個時候我們需要用到send()
方法的第三個參數。
//消息持久化 persistent為true,字符串的'true'
$result = $connect->send('email',json_encode($data),array('persistent'=>'true'));
前面我們完成了『發(fā)送』
給mq服務器發(fā)送消息(email消息)。
那么在mq的隊列中的任務,又是怎么處理的呢?
?php
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服務端,訂閱(監(jiān)聽)隊列消息。
在服務端是命令行下執(zhí)行: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
就把我們發(fā)送的內容讀取出來了。
我們循環(huán)讀取(死循環(huán))一直等待新消息:
do{
if ($connect->hasFrameToRead()){
$frame = $connect->readFrame();
print_r($frame->body);
}
} while (true);
處理消息之后(在發(fā)送郵件等業(yè)務完成之后),要通知mq我處理了該條消息了
if ($connect->hasFrameToRead()){
$frame = $connect->readFrame();
//print_r($frame->body);
//做業(yè)務邏輯
//具體發(fā)送郵件的業(yè)務
//send email
//最后通知mq,我們已經處理了該條消息
$connect->ack($frame);
}
我們還可以在優(yōu)化一下代碼,解決死循環(huán),控制循環(huán)(這里是一種方案演示)
do{
//會等待,直到有可用消息,才執(zhí)行后面代碼
if ($connect->hasFrameToRead()){
$frame = $connect->readFrame();
//print_r($frame->body);
//做業(yè)務邏輯
//具體發(fā)送郵件的業(yè)務
//send email
sleep(2); //模擬延時
//最后通知mq,我們已經處理了該條消息
$connect->ack($frame);
}
//控制循環(huán)
$next = true;
if (file_exists(__DIR__.'/stop')){
//如果有名為stop的一個文件
//就不循環(huán)了
$next = false;
}
} while ($next);
更多關于PHP相關內容感興趣的讀者可查看本站專題:《PHP數據結構與算法教程》、《php程序設計算法總結》、《php字符串(string)用法總結》、《PHP數組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結》及《PHP數學運算技巧總結》
希望本文所述對大家PHP程序設計有所幫助。
您可能感興趣的文章:- Spring Boot教程之利用ActiveMQ實現延遲消息
- SpringBoot整合ActiveMQ過程解析
- Apache ActiveMQ任意文件寫入漏洞(CVE-2016-3088)復現
- java怎么連接并訪問activemq
- Linux環(huán)境ActiveMQ部署方法詳解
- activemq整合springboot使用方法(個人微信小程序用)
- ActiveMQ:使用Python訪問ActiveMQ的方法
- ActiveMQ安裝及部署教程圖解