Consumer高級特性

人生的磨難是很多的黔州,所以我們不可對于每一件輕微的傷害都過于敏感辅搬。在生活磨難面前,精神上的堅強和無動于衷是我們抵抗罪惡和人生意外的最好武器索赏。 —— 洛克

1. 獨占消費者(Exclusive Consumer)

??Queue中的消息是按照順序被分發(fā)到consumers的侵贵。然而届搁,當你有多個consumers同時從相同的queue中提取消息時,你將失去這個保證窍育。因為這些消息是被多個線程并發(fā)的處理卡睦。有的時候,保證消息按照順序處理是很重要的漱抓。
??ActiveMQ提供了Exclusive Consumer機制表锻,Broker從多個Consumer中挑選一個Consumer來處理Queue中的所有消息。若是在此過程辽旋,這個Consumer掛掉浩嫌,則會自動切換到其他的Consumer繼續(xù)處理。
??可以通過Destination Options 來創(chuàng)建一個Exclusive Consumer补胚。如下

queue = new ActiveMQQueue("ORDER.PRICE?consumer.exclusive=true");
consumer = session.createConsumer(queue);

2. 消息分組(Message Groups)

??Message Groups可以看成是并發(fā)的Exclusive Consumer码耐,Message Groups機制中是使用JMS消息屬性的JMSXGroupID來區(qū)分的。Message Groups保證所有具有相同的JMSXGroupID的消息會被分發(fā)到相同的Consumer溶其。該特性也是一種負載均衡的機制骚腥。
??在消息被分發(fā)到Consumer前,Broker首先會檢查消息JMSXGroupID屬性瓶逃。若存在束铭,那么會檢查是否有具有該Message Group的Consumer。若沒有厢绝,Broker則會選擇一個Consumer契沫,將該關聯到Message Group上,此后該Consumer會接收該Message Group的所有消息昔汉。直到:
??(1) Consumer被關閉懈万。
??(2) Message group被關閉。發(fā)送一個消息,并設置該消息的JMSXGroupSeq為0会通。
??示例如下:

// 發(fā)送者:
Destination destination = session.createQueue("Order.Group.Queue");
MessageProducer messageProducer = session.createProducer(destination);
for(int i = 1; i <= 3; i++){
     TextMessage textMessage = session.createTextMessage("Message From OrderGroup-A:"  + i);
     textMessage.setStringProperty("JMSXGroupID", "OrderGroup-A");
     messageProducer.send(textMessage);
}
// 消費者
Destination destination = session.createQueue(");
MessageConsumer messageConsumer = session.createConsumer("Order.Group.Queue");
messageConsumer.setMessageListener(new MessageListener(){@Override
    public void onMessage(Message message) {
        try {
            System.out.println("收到的消息:" + ((TextMessage) message).getText());
        } catch (JMSException e) {
            e.printStackTrace();
        }
    }
});
// 執(zhí)行結果
INFO | Successfully connected to tcp://localhost:61616
收到的消息:Message From OrderGroup-A:1
收到的消息:Message From OrderGroup-B:1
收到的消息:Message From OrderGroup-A:2
收到的消息:Message From OrderGroup-B:2
收到的消息:Message From OrderGroup-A:3
收到的消息:Message From OrderGroup-B:3

??關閉一個Message Groups口予,只需要在message對象上設置屬性即可,如下:

message.setStringProperty("JMSXGroupID","OrderGroup-A");
message.setIntProperty("JMSXGroupSeq", -1);

3. 消息選擇器(JMS Selector)

??JMS Selectors用于在訂閱中涕侈,基于消息屬性對進行消息的過濾沪停。JMS Selectors由SQL92語法定義。如下面示例:

consumer = session.createConsumer(destination, "JMSType = 'car' AND weight > 2500");

??在JMS Selectors表達式中裳涛,可以使用IN木张、NOT IN、LIKE等调违,例如:
??(1)LIKE '12%3' ('123' true窟哺,'12993' true,'1234' false)
??(2)LIKE 'l_se' ('lose' true技肩,'loose' false)
??(3)LIKE '_%' ESCAPE '' ('_foo' true,'foo' false)
??需要注意的是浮声,JMS Selectors表達式中的日期和時間需要使用標準的long型毫秒值虚婿。另外表達式中的屬性不會自動進行類型轉換,例如:

message.setStringProperty("NumberOfOrders", "2"); //"NumberOfOrders > 1" 求值結果是false泳挥。

??Message Groups雖然可以保證具有相同message group的消息被唯一的consumer順序處理然痊,但是卻不能確定被哪個consumer處理。在某些情況下屉符,Message Groups可以和JMS Selector一起工作,如:
??有三個consumers分別是A剧浸、B和C。你可以在producer中為消息設置三個message groups分別是“A”矗钟、“B”和“C”唆香。然后令consumer A使用“JMXGroupID = ‘A’”作為selector。B和C也同理吨艇。這樣就可以保證message group A的消息只被consumer A處理躬它。需要注意的是,這種做法有以下缺點:
??(1) producer必須知道當前正在運行的consumers东涡。
??(2) 如果某個consumer失效冯吓,那么應該被這個consumer消費的消息將會一直被積壓在broker上。

?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末疮跑,一起剝皮案震驚了整個濱河市组贺,隨后出現的幾起案子,更是在濱河造成了極大的恐慌祖娘,老刑警劉巖失尖,帶你破解...
    沈念sama閱讀 221,198評論 6 514
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡雹仿,警方通過查閱死者的電腦和手機增热,發(fā)現死者居然都...
    沈念sama閱讀 94,334評論 3 398
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來胧辽,“玉大人峻仇,你說我怎么就攤上這事∫厣蹋” “怎么了摄咆?”我有些...
    開封第一講書人閱讀 167,643評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長人断。 經常有香客問我吭从,道長,這世上最難降的妖魔是什么恶迈? 我笑而不...
    開封第一講書人閱讀 59,495評論 1 296
  • 正文 為了忘掉前任涩金,我火速辦了婚禮,結果婚禮上暇仲,老公的妹妹穿的比我還像新娘步做。我一直安慰自己,他們只是感情好奈附,可當我...
    茶點故事閱讀 68,502評論 6 397
  • 文/花漫 我一把揭開白布全度。 她就那樣靜靜地躺著,像睡著了一般斥滤。 火紅的嫁衣襯著肌膚如雪将鸵。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,156評論 1 308
  • 那天佑颇,我揣著相機與錄音顶掉,去河邊找鬼。 笑死漩符,一個胖子當著我的面吹牛一喘,可吹牛的內容都是我干的。 我是一名探鬼主播嗜暴,決...
    沈念sama閱讀 40,743評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼凸克,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了闷沥?” 一聲冷哼從身側響起萎战,我...
    開封第一講書人閱讀 39,659評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎舆逃,沒想到半個月后蚂维,有當地人在樹林里發(fā)現了一具尸體戳粒,經...
    沈念sama閱讀 46,200評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,282評論 3 340
  • 正文 我和宋清朗相戀三年虫啥,在試婚紗的時候發(fā)現自己被綠了蔚约。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,424評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡涂籽,死狀恐怖苹祟,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情评雌,我是刑警寧澤树枫,帶...
    沈念sama閱讀 36,107評論 5 349
  • 正文 年R本政府宣布,位于F島的核電站景东,受9級特大地震影響砂轻,放射性物質發(fā)生泄漏。R本人自食惡果不足惜斤吐,卻給世界環(huán)境...
    茶點故事閱讀 41,789評論 3 333
  • 文/蒙蒙 一搔涝、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧曲初,春花似錦体谒、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,264評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽幌绍。三九已至颁褂,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間傀广,已是汗流浹背颁独。 一陣腳步聲響...
    開封第一講書人閱讀 33,390評論 1 271
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留伪冰,地道東北人誓酒。 一個月前我還...
    沈念sama閱讀 48,798評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像贮聂,于是被迫代替她去往敵國和親靠柑。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,435評論 2 359

推薦閱讀更多精彩內容

  • 姓名:周小蓬 16019110037 轉載自:http://blog.csdn.net/YChenFeng/art...
    aeytifiw閱讀 34,727評論 13 425
  • 一吓懈、入門1歼冰、簡介Kafka is a distributed,partitioned,replicated com...
    HxLiang閱讀 3,352評論 0 9
  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現耻警,斷路器隔嫡,智...
    卡卡羅2017閱讀 134,693評論 18 139
  • 本文轉載自http://dataunion.org/?p=9307 背景介紹Kafka簡介Kafka是一種分布式的...
    Bottle丶Fish閱讀 5,475評論 0 34
  • 背景介紹 Kafka簡介 Kafka是一種分布式的甸怕,基于發(fā)布/訂閱的消息系統(tǒng)。主要設計目標如下: 以時間復雜度為O...
    高廣超閱讀 12,841評論 8 167