您好,登錄后才能下訂單哦!
如何保證RabbitMQ的消息的順序性,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
對于這個問題,我查閱很多網上的資料,大體來說主流的解決方案有兩種:
一種是使用單線程消費來保證消息的順序性
對消息進行編號,消費者處理時根據編號來判斷順序
乍一看,覺得兩種方案沒有什么問題,但是深入了解下,覺得這兩種解決方案并不能完全接保證消息的消費的順序性問題。
首先我們來分析下,是什么導致RabbitMQ消息的順序性問題的,常見的有以下幾種情形:
消息生產者啟用了發送確認機制,在發生超時、中斷等,需要RabbitMQ補償發送時,那么此時消息在源頭就已經出現順序混亂了,導致消息被消費時也是亂序的
另一種情況,如果消息發送時,設置了超時時間,并且采用了死信隊列,模擬了延時隊列的效果,那么此時消息的順序也時不能保證的
還有一種情況,如果消息設置了優先級,那么在高并發的情況下,消息的順序也是得不到保證的,消息的消費順序也就不能保證了
剛才我們分析了出現消息亂序的幾種情況,這里我們首先排除了實用單線程來消費,原因很簡單,發送的消息的順序(源頭數據的順序出現了異常)出現了異常,單線程消費的順序肯定也是異常的
其次對消息進行編號,這個可以解決消息順序的問題,但是對加大了對業務處理的復雜性
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。