亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

pushConsumer拉取消息流程是怎樣的

發布時間:2021-12-18 14:49:42 來源:億速云 閱讀:143 作者:iii 欄目:大數據

這篇文章主要介紹“pushConsumer拉取消息流程是怎樣的”,在日常操作中,相信很多人在pushConsumer拉取消息流程是怎樣的問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”pushConsumer拉取消息流程是怎樣的”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

這是一段RocketMq經典的consumer異步獲取broker消息的代碼:

    DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("consumerGroup");    consumer.setNamesrvAddr(Constants.NameServerAddr);    consumer.subscribe("topic01","*");    consumer.setMessageModel(MessageModel.BROADCASTING);//廣播消息,所有相同組,定于topic的消費端都能收到消息    //consumer.setMessageModel(MessageModel.CLUSTERING);//集群消息--默認(相同組內的topic,集群消息只有一端會接收到)    consumer.registerMessageListener(new MessageListenerConcurrently(){      @Override      public ConsumeConcurrentlyStatus consumeMessage(List<MessageExt> list,          ConsumeConcurrentlyContext consumeConcurrentlyContext) {        for (MessageExt messageExt:list){          System.out.println(new java.lang.String(messageExt.getBody()));        }        return ConsumeConcurrentlyStatus.CONSUME_SUCCESS;      }    });    consumer.start();  }

consumer start()方法跟蹤

  1. this.defaultMQPushConsumerImpl.start();

  2. 剛啟動serviceState狀態為 CREATE_JUST,進入這個狀態的switch處理邏輯

3. 先用checkCoing()檢查consumer的各個配置是否配置ok

4. 然后 copySubscription()用于根據subject構建本地的rebalance的conhurrentHashMapInner

5. 接著構建MqClientFactory的一個Instance

6. 構建PullWrapper,用于去Broker注冊過濾消息

7. 再根據MessageMode是廣播模式還是集群模式獲取offset。(廣播模式是從consumer本地的store獲取,集群模式則是需要去broker去請求獲取)

8. 根據監聽消息的類型是OrderLy還是Concurrently去構建一個consumeMessageService對象

9.啟動剛才創建的consumerMessageService對象,調用其start方法

10. 使用MqClientFactory Instance實例registerConsumer進行注冊

11. 把當前的serviceState狀態變為Running狀態

12.然后就開始從broker獲取消息,請看下面的pushConsumer拉取消息流程

pushConsumer拉取消息流程介紹 

consumer  --DefaultMqPushConsumerImpl 使用pullMessage(pullRequest)拉取消息,pullAPIWrapper.pullKernelImpl(傳遞pullReuest,回調callback等參數)根據是否同步pullMessageSync還是異步pullMessageAsync, 拉取回來的消息PullResult經過解析處理存放到ProcessQueue 隊列里的TreeMap(offset,messageExt)

到此,關于“pushConsumer拉取消息流程是怎樣的”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

东光县| 安远县| 阜平县| 咸阳市| 万宁市| 眉山市| 莱西市| 吴旗县| 五指山市| 琼结县| 连江县| 宁陕县| 防城港市| 抚远县| 廉江市| 宝应县| 武冈市| 河南省| 吴江市| 龙陵县| 宜章县| 梅州市| 墨竹工卡县| 谢通门县| 都兰县| 宜良县| 牙克石市| 宁晋县| 永胜县| 曲水县| 阜阳市| 光泽县| 新河县| 改则县| 兰考县| 搜索| 江永县| 澎湖县| 松溪县| 衡阳市| 昌都县|