文章詳情頁
java - 并發(fā)操作下關(guān)于隊(duì)列的疑問?
瀏覽:73日期:2023-10-26 15:47:21
問題描述
常用的rabbitmq,activeMq隊(duì)列,多個(gè)消費(fèi)者或者多個(gè)線程去取隊(duì)列中的數(shù)據(jù),會(huì)不會(huì)出現(xiàn)不同消費(fèi)者同時(shí)到達(dá)取到同一個(gè)數(shù)據(jù)的情況?目前只知道redis由于是單線程的,做隊(duì)列的時(shí)候可以避免這種情況。
問題解答
回答1:消息隊(duì)列的發(fā)布訂閱模式有多種,有一個(gè)消息多個(gè)消費(fèi)者都能獲取到的模式,有一個(gè)消息發(fā)送到指定消費(fèi)者模式,選擇合適你自己的~你說的這種可以用rabbitmq的direct模式
回答2:任何消息隊(duì)列,只要自稱是消息隊(duì)列服務(wù)的,都會(huì)保證這點(diǎn),無須擔(dān)心。但要注意的是,消息隊(duì)列有兩種模式,生產(chǎn)者消費(fèi)者模式和發(fā)布者訂閱者模式,前者保證每條消息只會(huì)被消費(fèi)一次,后者保證每條消息能達(dá)到所有的訂閱者,因此被消費(fèi)的次數(shù)不確定。
標(biāo)簽:
java
相關(guān)文章:
1. docker gitlab 如何git clone?2. docker容器呢SSH為什么連不通呢?3. docker鏡像push報(bào)錯(cuò)4. macos - mac下docker如何設(shè)置代理5. docker start -a dockername 老是卡住,什么情況?6. css - ionic中的柵格布局如何讓文字內(nèi)容多少不同的每一列中的內(nèi)容都能垂直居中?7. Docker for Mac 創(chuàng)建的dnsmasq容器連不上/不工作的問題8. angular.js使用$resource服務(wù)把數(shù)據(jù)存入mongodb的問題。9. css3 - 為什么css里面要帶-moz-|-webkit-后又來一個(gè)不帶它們的10. docker 下面創(chuàng)建的IMAGE 他們的 ID 一樣?這個(gè)是怎么回事????
排行榜

熱門標(biāo)簽