本文實(shí)例講述了PHP使用ActiveMQ實(shí)現(xiàn)消息隊(duì)列的方法。分享給大家供大家參考,具體如下:
前面我們已經(jīng)學(xué)了如何部署ActiveMQ,
我們知道通過(guò)ActiveMQ的一個(gè)管理后臺(tái)可以查看任務(wù)隊(duì)列。
用PHP來(lái)操作ActiveMQ,我們可以借助一個(gè)第三方擴(kuò)展。
下載:
composer require fusesource/stomp-php:2.0.*
然后新建test.php:
<?phprequire __DIR__.'/vendor/autoload.php'; //引入自動(dòng)加載的文件$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)
我們?cè)贏ctiveMQ自帶的管理后臺(tái)查看,確實(shí)有一個(gè)名為”email”的隊(duì)列。
上面我們發(fā)送的一個(gè)id,我們還可以發(fā)送json數(shù)據(jù)。
$data = array('id'=>1001,'email'=>'110@qq.com','content'=>'test');$result = $connect->send('email',json_encode($data)); 我們?cè)贛Q后臺(tái)可以查看消息詳細(xì)
上面的代碼到這里,還不夠完美。如果我們服務(wù)器重啟了activemq,沒(méi)有處理的消息會(huì)丟失。
這個(gè)時(shí)候我們需要用到send()方法的第三個(gè)參數(shù)。
//消息持久化 persistent為true,字符串的'true'$result = $connect->send('email',json_encode($data),array('persistent'=>'true')); 給mq服務(wù)器發(fā)送消息(email消息)。
那么在mq的隊(duì)列中的任務(wù),又是怎么處理的呢?
<?phprequire __DIR__.'/vendor/autoload.php'; //引入自動(dòng)加載的文件$connect = new /FuseSource/Stomp/Stomp('tcp://10.211.55.13/:61613');$connect->connect();//訂閱隊(duì)列消息$connect->subscribe('email');if ($connect->hasFrameToRead()){ $frame = $connect->readFrame(); print_r($frame);} 在mq服務(wù)端,訂閱(監(jiān)聽(tīng))隊(duì)列消息。
在服務(wù)端是命令行下執(zhí)行:php mqServer.php
如果有沒(méi)有處理的消息,可以讀取出來(lái),打印結(jié)果如下:
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ā)送的內(nèi)容讀取出來(lái)了。
我們循環(huán)讀取(死循環(huán))一直等待新消息:
do{ if ($connect->hasFrameToRead()){ $frame = $connect->readFrame(); print_r($frame->body); }} while (true);處理消息之后(在發(fā)送郵件等業(yè)務(wù)完成之后),要通知mq我處理了該條消息了
if ($connect->hasFrameToRead()){ $frame = $connect->readFrame(); //print_r($frame->body); //做業(yè)務(wù)邏輯 //具體發(fā)送郵件的業(yè)務(wù) //send email //最后通知mq,我們已經(jīng)處理了該條消息 $connect->ack($frame); }我們還可以在優(yōu)化一下代碼,解決死循環(huán),控制循環(huán)(這里是一種方案演示)
do{ //會(huì)等待,直到有可用消息,才執(zhí)行后面代碼 if ($connect->hasFrameToRead()){ $frame = $connect->readFrame(); //print_r($frame->body); //做業(yè)務(wù)邏輯 //具體發(fā)送郵件的業(yè)務(wù) //send email sleep(2); //模擬延時(shí) //最后通知mq,我們已經(jīng)處理了該條消息 $connect->ack($frame); } //控制循環(huán) $next = true; if (file_exists(__DIR__.'/stop')){ //如果有名為stop的一個(gè)文件 //就不循環(huán)了 $next = false; }} while ($next);更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結(jié)》及《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
新聞熱點(diǎn)
疑難解答
圖片精選