91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

如何解決RocketMQ消息消費異常

發布時間:2021-10-20 10:58:55 來源:億速云 閱讀:2998 作者:iii 欄目:編程語言

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

發現問題:

開發中在項目重啟時會重復消費消息,但其實消息已經消費過了。

查找問題:

1.RocketMq console查看,發現訂閱組消息延遲

如何解決RocketMQ消息消費異常

2.從消息看message Detail 對應的consumerGroup trackType為 not conume yet

如何解決RocketMQ消息消費異常

3.項目日志也沒有任何錯誤日志,然而根據相關業務查詢數據庫發現數據已經處理完成
4.業務代碼斷點,沒有拋出任何異常,通過resend message也能正常消費
5.懷疑是不是rocketMq 更新offset的定時任務沒有啟動

然而通過源碼斷點MQClientInstance 定時任務正常,只是每次更新的offset都是原offet如何解決RocketMQ消息消費異常

6.看看是不是消費的時候出了問題

由于是用的spring-boot整合的client,跟蹤consumer源碼,代碼在DefaultRocketMQListenerContainer.handleMessage方法中

然而一切正常,再往上跟蹤到DefaultMessageListenerConcurrently

public class DefaultMessageListenerConcurrently implements MessageListenerConcurrently {

        @SuppressWarnings("unchecked")
        @Override
        public ConsumeConcurrentlyStatus consumeMessage(List<MessageExt> msgs, ConsumeConcurrentlyContext context) {
            for (MessageExt messageExt : msgs) {
                log.debug("received msg: {}", messageExt);
                try {
                    long now = System.currentTimeMillis();
                    handleMessage(messageExt);
                    long costTime = System.currentTimeMillis() - now;
                    log.debug("consume {} cost: {} ms", messageExt.getMsgId(), costTime);
                } catch (Exception e) {
                    log.warn("consume message failed. messageExt:{}, error:{}", messageExt, e);
                    context.setDelayLevelWhenNextConsume(delayLevelWhenNextConsume);
                    return ConsumeConcurrentlyStatus.RECONSUME_LATER;
                }
            }

            return ConsumeConcurrentlyStatus.CONSUME_SUCCESS;
        }
    }

首先在catch代碼塊點打斷點看看是不是有問題,結果發現并沒有走到這里,這就坑爹了,害我又從其它方面各種查原因,浪費了很多時間。后面一步一步調試,最終在 log.debug("consume {} cost: {} ms", messageExt.getMsgId(), costTime); 打日志這一步時拋出了異常,這尼瑪打個日志還能異常,還不是Exception的異常。。本來松了口氣以為找到了原因就好解決了,沒想到這才是剛剛開始。

7.在往上層調用代碼ConsumeMessageConcurrentlyService里斷點查看異常信息

java.lang.NoClassDefFoundError:Could not initialize class org.apache.rocketmq.common.message.MessageClientIDSetter

如何解決RocketMQ消息消費異常

原因是在MessageClientExt類中調用getMsgId方法里,調用了MessageClientIDSetter.getUniqID(this)直接拋出的異常

如何解決RocketMQ消息消費異常

從異常信息來看是MessageClientIDSetter 在初始化的時候出了問題

8.查看MessageClientIDSetter原碼,有一斷靜態代碼塊,然后在這里斷點跟蹤。
static {
        byte[] ip;
        try {
            ip = UtilAll.getIP();
        } catch (Exception e) {
            ip = createFakeIP();
        }
        LEN = ip.length + 2 + 4 + 4 + 2;
        ByteBuffer tempBuffer = ByteBuffer.allocate(ip.length + 2 + 4);
        tempBuffer.position(0);
        tempBuffer.put(ip);
        tempBuffer.position(ip.length);
        tempBuffer.putInt(UtilAll.getPid());
        tempBuffer.position(ip.length + 2);
        tempBuffer.putInt(MessageClientIDSetter.class.getClassLoader().hashCode());
        FIX_STRING = UtilAll.bytes2string(tempBuffer.array());
        setStartTime(System.currentTimeMillis());
        COUNTER = new AtomicInteger(0);
    }

發面是在ip = UtilAll.getIP();出了問題,然則并沒有到catch代碼塊,而是跳到了DefaultMqPushConsumerImpl類中,這里又一個坑爹的是異常塊沒有任何處理,看不到異常信息,好吧只能一步一步繼續斷點調試

如何解決RocketMQ消息消費異常

最終在UtillAll類的ipV6Check方法執行到InetAddressValidator.getInstance();出了問題。

private static boolean ipV6Check(byte[] ip) {
        if (ip.length != 16) {
            throw new RuntimeException("illegal ipv6 bytes");
        }

        InetAddressValidator validator = InetAddressValidator.getInstance();
        return validator.isValidInet6Address(ipToIPv6Str(ip));
    }

但是在本地調試這段代碼又沒有任何問題。因此只能在debug時調試,報的錯是classNotFound異常

9.這又是坑爹的問題,源碼上看著類也能找到,最后查看maven依賴,才發現有jar包沖突。

如何解決RocketMQ消息消費異常

從rocketMq的依賴來看他需要的版本是1.6

如何解決RocketMQ消息消費異常

因此我們需要把1.3.1的版本移除

10.查找依賴1.3.1版本的commons-validator

看著這密密麻麻的依賴關系,Idea還沒有查找功能,只能慢慢找了,最后功夫不復有心人,把依賴移除,重啟一切都好了

如何解決RocketMQ消息消費異常

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

向AI問一下細節

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

AI

布尔津县| 锦州市| 诏安县| 宜宾市| 阿拉善右旗| 洪湖市| 靖远县| 巴马| 遵义市| 林口县| 伊宁县| 玉林市| 泗洪县| 泾川县| 饶河县| 醴陵市| 工布江达县| 金门县| 垫江县| 朝阳区| 西华县| 连州市| 新源县| 彩票| 石家庄市| 洛宁县| 岳阳县| 鹤峰县| 将乐县| 静安区| 平谷区| 花莲县| 正安县| 武宁县| 北票市| 邛崃市| 临安市| 兴安县| 灯塔市| 郧西县| 岳池县|