主頁 > 知識庫 > PHP加MySQL消息隊列深入理解

PHP加MySQL消息隊列深入理解

熱門標簽:地圖標注平臺怎么給錢注冊 注冊400電話申請 衡水外呼系統(tǒng)平臺 安裝電銷外呼系統(tǒng) 釘釘打卡地圖標注 百度商鋪地圖標注 常州地圖標注服務(wù)商 新河科技智能外呼系統(tǒng)怎么樣 福州人工外呼系統(tǒng)哪家強

消息隊列:在消息的傳輸過程中保存消息的容器。
消息隊列管理器在將消息從它的源中繼到它的目標時充當中間人。隊列的主要目的是提供路由并保證消息的傳遞;如果發(fā)送消息時接收者不可用,消息隊列會保留消息,直到可以成功地傳遞它。

如圖所示
在不使用消息隊列的情況下,用戶的請求數(shù)據(jù)直接寫入數(shù)據(jù)庫,再高并發(fā)的情況下,會對數(shù)據(jù)庫造成巨的壓力,同時也使得響應(yīng)延遲加劇。在使用消息隊列后,用戶請求的數(shù)據(jù)發(fā)送給消息隊列后立即返回,再由消息隊列的消費者進程(通常情況下,該進程獨立部署在專門的服務(wù)器集群上)從消息隊列中獲取數(shù)據(jù),異步寫入數(shù)據(jù)庫。由于消息隊列服務(wù)器處理速度遠大于數(shù)據(jù)庫,因此用戶的響應(yīng)延遲可得到有效改善。

尤其是在淘寶搞“雙十一”,“春節(jié)特賣”等活動時,使用消息隊列有很好的削峰作用--------
即通過異步處理,將短時間高并發(fā)產(chǎn)生的事務(wù)消息存儲在消息隊列中,從而削平高峰期的并發(fā)事務(wù)。所以在一些電子商務(wù)網(wǎng)站促銷活動中,合理使用消息隊列,可有效抵御促銷活動剛開始大量涌入的訂單對系統(tǒng)造成的沖擊。


需要注意的是,由于數(shù)據(jù)寫入消息隊列后立即返回給用戶數(shù)據(jù)在后續(xù)的業(yè)務(wù)校驗、寫數(shù)據(jù)庫等操作可能失敗,因此在使用消息隊列進行業(yè)務(wù)異步處理后,需要適當修改業(yè)務(wù)流程進行配合,如訂單提交后,訂單數(shù)據(jù)寫入消息隊列,不能立即返回用戶訂單提交成功,需要在消息隊列的訂單消費者進程真正處理完該訂單,甚至商品出庫后,再通過電子郵件或SMS消息通知用戶訂單成功,以免交易糾紛。

最近遇到一個批量發(fā)送短信的需求,短信接口是第三方提供的。剛開始想到,獲取到手機號之后,循環(huán)調(diào)用接口發(fā)送不就可以了嗎?

但很快發(fā)現(xiàn)問題:當短信數(shù)量很大時,不僅耗時,而且成功率很低。

于是想到,用PHP和MySQL實現(xiàn)一個消息隊列,一條一條的發(fā)送短信。下面介紹具體的實現(xiàn)方法:

首先,建立一個數(shù)據(jù)表sms,包含以下字段:

id,
phone, //手機號
content //短信內(nèi)容

將需要發(fā)送的短信和手機號存入sms表中。

接下來,需要用PHP實現(xiàn)一個定時器,定時讀取一條記錄,并發(fā)送短信:

?php
$db = new Db();
$sms = new Sms();
while(true){
  $item = $db->getFirstRecord(); //獲取數(shù)據(jù)表第一條記錄
  if(!$item){
    //如果隊列中沒有數(shù)據(jù),則結(jié)束定時器
    break;
  }
  $res = $sms->send($item['phone'],$item['content']); //發(fā)送短信
  if($res){
    $db->deleteFristRecord(); //刪除發(fā)送成功的記錄
    echo $item['phone'].'發(fā)送成功';
  }else{
    echo $item['phone'].'發(fā)送失敗,稍后繼續(xù)嘗試';
  }
  sleep(10); //每隔十秒循環(huán)一次      
}
 
echo '發(fā)送完畢!';
?>

將代碼保存為timer_sms.php,打開命令行,執(zhí)行定時器:

php timer_sms.php

到此這篇關(guān)于PHP+MySQL消息隊列深入理解的文章就介紹到這了,更多相關(guān)PHP+MySQL消息隊列內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Android和PHP MYSQL交互開發(fā)實例
  • Mac M1安裝mnmp(Mac+Nginx+MySQL+PHP)開發(fā)環(huán)境
  • PHP+Mysql分布式事務(wù)與解決方案深入理解
  • PHP連接MySQL數(shù)據(jù)庫三種實現(xiàn)方法
  • 深入理解PHP+Mysql分布式事務(wù)與解決方案
  • Aliyun Linux 編譯安裝 php7.3 tengine2.3.2 mysql8.0 redis5的過程詳解
  • php7連接MySQL實現(xiàn)簡易查詢程序的方法
  • PHP之mysql位運算案例講解

標簽:唐山 鷹潭 白城 柳州 鶴崗 遼陽 克拉瑪依 六安

巨人網(wǎng)絡(luò)通訊聲明:本文標題《PHP加MySQL消息隊列深入理解》,本文關(guān)鍵詞  PHP,加,MySQL,消息,隊列,深入,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP加MySQL消息隊列深入理解》相關(guān)的同類信息!
  • 本頁收集關(guān)于PHP加MySQL消息隊列深入理解的相關(guān)信息資訊供網(wǎng)民參考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推薦文章