訊息佇列MQ ,本質是個佇列,其最簡單的操作就是入隊和出隊,既按照程序決定何時何條件入隊,和何時何條件出隊。也就是說,遇到入隊系統和出隊系統的業務訴求不一致時的場景,就可以考慮是否用訊息佇列來實現了。可應用場景有很多,以下是幾個常見的場景和解釋。
一:非同步處理、應用解耦、分散式
場景:主業務對子業務的處理結果並不關心時。
案例:電商系統中訂單系統、物流系統、財務系統、操作日誌記錄系統之間的關係。
通俗解釋:小明是個蛋糕店員。他做好蛋糕後,放在櫥窗中,在對應訂單上標記‘已完成’,然後繼續做下一個蛋糕,並不關心蛋糕後續是怎麼賣出的,也不關心啥時候賣出。
實作:使用一個佇列的中間件或中間系統來存放幾個業務系統的共用部分,並獨立處理。可使用每個系統各自的獨立標記,對各系統的處理進度進行記錄。在所有系統完成操作後,進行出隊操作,或持久化儲存資料。
注意點:需要考慮中間資料的容災能力,當故障發生並復原時,確保業務流程可以復原。確保每個資料都可以正確地完成處理。
二:峰值處理
#場景:流量在各個時間點不均衡
案例:秒殺、搶購
解釋:小明製作蛋糕的時間比較長,訂單來到後先登記成一個清單,然後逐次按順序製作,訂單量過大時,會暫時掛出『已售完』的牌子。
實作: 使用單執行緒的工具將業務需求進行排隊處理。當業務請求達到閥值時,給予友善提示並拒絕使用者的需求。
注意點:對於消峰需求,可以高峰期掛出『暫時無法購買,請稍等』等提示,防止流量對後續業務的衝擊。對於秒殺等搶完即停的需求,需要考慮超額問題,可以添加一個名額計數器,或者在秒殺名額已滿員時,發放一個秒殺完成標記,後續處理程序檢測到完成標記後,再進行後續處理。
三:送達保證
場景:內容需要逐條嚴格執行,並保證執行成功,執行不成功或中斷時,可以恢復
案例:銀行、財務類系統,需提升災難能力的系統
解釋:小明製作的蛋糕需要客戶驗貨簽收後,才可以繼續製作下一個蛋糕。
實作:入隊系統將業務需求寫入訊息佇列後,即進行下一次業務處理。後續處理程序將佇列內容逐條處理,處理完成後發放『完成許可』。訊息佇列中的內容,只有取得『完成許可』後,才可以從訊息佇列中刪除。
注意:重點考慮災難相關問題,如業務復原問題、重複處理問題。
四:排序保證
場景:訊息佇列中的內容有嚴格的順序。
案例:搶號排隊等系統
解釋:小明製作蛋糕的順序需要嚴格按下單一順序來製作。
實作:入隊系統將內容逐條寫入訊息佇列,並依照單線排列,依照先進先出的順序來提出資料並進行後續處理。
注意點:需要使用單線程,保證只有一條生產線。
五:擴展性
場景:採用發布-訂閱模式時,新增新的訂閱者
案例:註冊用戶後,在發送成功簡訊的模型中,追加一個發送email的功能
實現: 由多個消費者訂閱一個訊息的中間層,然後發布者將訊息發佈到中間層中。 訂閱了這個中間層的消費者均可以收到這個訊息,並進行後續處理。在這個結構中。如果想要新增一個訊息的後續處理元件 ,只需要將這個元件訂閱到中間層即可
注意點:確保業務之間沒有深度耦合,防止擴展時造成乾擾。
以上就是訊息佇列比較常用的幾種場景,訊息佇列可以平覆系統之間的差異,提高系統穩定性,適用場景還有很多。
在訊息佇列媒體選擇時,建議同學們不用在一開始就一定要將條件和目標最大化,一定要以什麼樣的條件完善完美的解決問題,程式還是需要一個長久維護與優化的過程。
雖然Redis在高流量且需要大量持久化資料等情況下,效能下降還是很嚴重的,但是還是建議大家從Redis來學習隊列,在課程中僅是透過改流程理解隊列的應用場景和思路,任何線上專案都是不斷優化與完善的,如果想透過一套影片完善的解決所有的問題,對不起臣妾做不到,每個工作的需求和應用場景都不同所以在有不同需求時就根據具體需求進行完善。
在判斷佇列需求時候,需要判斷佇列條件應用時加入計數器欄位在每次壓入佇列時判斷目前佇列的長度數量,如果數量超過限定的秒殺數量不在進入佇列程式。
在實際使用時,並不需要刻意追求哪些地方需要新增訊息佇列。而應依照實際情況,在進行業務分離和解耦合,以及一些特殊訴求時合理地選擇運用。
以上是PHP之消息佇列的詳細內容。更多資訊請關注PHP中文網其他相關文章!

PHP和Python各有優勢,選擇應基於項目需求。 1.PHP適合web開發,語法簡單,執行效率高。 2.Python適用於數據科學和機器學習,語法簡潔,庫豐富。

PHP不是在消亡,而是在不斷適應和進化。 1)PHP從1994年起經歷多次版本迭代,適應新技術趨勢。 2)目前廣泛應用於電子商務、內容管理系統等領域。 3)PHP8引入JIT編譯器等功能,提升性能和現代化。 4)使用OPcache和遵循PSR-12標準可優化性能和代碼質量。

PHP的未來將通過適應新技術趨勢和引入創新特性來實現:1)適應云計算、容器化和微服務架構,支持Docker和Kubernetes;2)引入JIT編譯器和枚舉類型,提升性能和數據處理效率;3)持續優化性能和推廣最佳實踐。

在PHP中,trait適用於需要方法復用但不適合使用繼承的情況。 1)trait允許在類中復用方法,避免多重繼承複雜性。 2)使用trait時需注意方法衝突,可通過insteadof和as關鍵字解決。 3)應避免過度使用trait,保持其單一職責,以優化性能和提高代碼可維護性。

依賴注入容器(DIC)是一種管理和提供對象依賴關係的工具,用於PHP項目中。 DIC的主要好處包括:1.解耦,使組件獨立,代碼易維護和測試;2.靈活性,易替換或修改依賴關係;3.可測試性,方便注入mock對象進行單元測試。

SplFixedArray在PHP中是一種固定大小的數組,適用於需要高性能和低內存使用量的場景。 1)它在創建時需指定大小,避免動態調整帶來的開銷。 2)基於C語言數組,直接操作內存,訪問速度快。 3)適合大規模數據處理和內存敏感環境,但需謹慎使用,因其大小固定。

PHP通過$\_FILES變量處理文件上傳,確保安全性的方法包括:1.檢查上傳錯誤,2.驗證文件類型和大小,3.防止文件覆蓋,4.移動文件到永久存儲位置。

JavaScript中處理空值可以使用NullCoalescingOperator(??)和NullCoalescingAssignmentOperator(??=)。 1.??返回第一個非null或非undefined的操作數。 2.??=將變量賦值為右操作數的值,但前提是該變量為null或undefined。這些操作符簡化了代碼邏輯,提高了可讀性和性能。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。