中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

如何解決RocketMQ消息消費(fèi)異常

這篇文章主要介紹“如何解決RocketMQ消息消費(fèi)異?!?,在日常操作中,相信很多人在如何解決RocketMQ消息消費(fèi)異常問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”如何解決RocketMQ消息消費(fèi)異?!钡囊苫笥兴鶐椭?!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!

創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括東阿網(wǎng)站建設(shè)、東阿網(wǎng)站制作、東阿網(wǎng)頁(yè)制作以及東阿網(wǎng)絡(luò)營(yíng)銷策劃等。多年來(lái),我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,東阿網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到東阿省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

發(fā)現(xiàn)問(wèn)題:

開(kāi)發(fā)中在項(xiàng)目重啟時(shí)會(huì)重復(fù)消費(fèi)消息,但其實(shí)消息已經(jīng)消費(fèi)過(guò)了。

查找問(wèn)題:

1.RocketMq console查看,發(fā)現(xiàn)訂閱組消息延遲

如何解決RocketMQ消息消費(fèi)異常

2.從消息看message Detail 對(duì)應(yīng)的consumerGroup trackType為 not conume yet

如何解決RocketMQ消息消費(fèi)異常

3.項(xiàng)目日志也沒(méi)有任何錯(cuò)誤日志,然而根據(jù)相關(guān)業(yè)務(wù)查詢數(shù)據(jù)庫(kù)發(fā)現(xiàn)數(shù)據(jù)已經(jīng)處理完成
4.業(yè)務(wù)代碼斷點(diǎn),沒(méi)有拋出任何異常,通過(guò)resend message也能正常消費(fèi)
5.懷疑是不是rocketMq 更新offset的定時(shí)任務(wù)沒(méi)有啟動(dòng)

然而通過(guò)源碼斷點(diǎn)MQClientInstance 定時(shí)任務(wù)正常,只是每次更新的offset都是原offet如何解決RocketMQ消息消費(fèi)異常

6.看看是不是消費(fèi)的時(shí)候出了問(wèn)題

由于是用的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代碼塊點(diǎn)打斷點(diǎn)看看是不是有問(wèn)題,結(jié)果發(fā)現(xiàn)并沒(méi)有走到這里,這就坑爹了,害我又從其它方面各種查原因,浪費(fèi)了很多時(shí)間。后面一步一步調(diào)試,最終在 log.debug("consume {} cost: {} ms", messageExt.getMsgId(), costTime); 打日志這一步時(shí)拋出了異常,這尼瑪打個(gè)日志還能異常,還不是Exception的異常。。本來(lái)松了口氣以為找到了原因就好解決了,沒(méi)想到這才是剛剛開(kāi)始。

7.在往上層調(diào)用代碼ConsumeMessageConcurrentlyService里斷點(diǎn)查看異常信息

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

如何解決RocketMQ消息消費(fèi)異常

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

如何解決RocketMQ消息消費(fèi)異常

從異常信息來(lái)看是MessageClientIDSetter 在初始化的時(shí)候出了問(wèn)題

8.查看MessageClientIDSetter原碼,有一斷靜態(tài)代碼塊,然后在這里斷點(diǎn)跟蹤。
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);
    }

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

如何解決RocketMQ消息消費(fèi)異常

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

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));
    }

但是在本地調(diào)試這段代碼又沒(méi)有任何問(wèn)題。因此只能在debug時(shí)調(diào)試,報(bào)的錯(cuò)是classNotFound異常

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

如何解決RocketMQ消息消費(fèi)異常

從rocketMq的依賴來(lái)看他需要的版本是1.6

如何解決RocketMQ消息消費(fèi)異常

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

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

看著這密密麻麻的依賴關(guān)系,Idea還沒(méi)有查找功能,只能慢慢找了,最后功夫不復(fù)有心人,把依賴移除,重啟一切都好了

如何解決RocketMQ消息消費(fèi)異常

到此,關(guān)于“如何解決RocketMQ消息消費(fèi)異?!钡膶W(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!

當(dāng)前標(biāo)題:如何解決RocketMQ消息消費(fèi)異常
轉(zhuǎn)載來(lái)于:http://www.rwnh.cn/article30/ippopo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、網(wǎng)站建設(shè)、搜索引擎優(yōu)化動(dòng)態(tài)網(wǎng)站、電子商務(wù)、定制網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名
昌图县| 右玉县| 南皮县| 蒙山县| 晋中市| 徐闻县| 澄城县| 科技| 佛山市| 托克托县| 绥棱县| 句容市| 永善县| 监利县| 海安县| 北海市| 平乡县| 武功县| 大荔县| 柘城县| 石狮市| 北海市| 安化县| 宕昌县| 肃宁县| 扎囊县| 凌云县| 岑巩县| 唐海县| 通渭县| 镇赉县| 广汉市| 湟源县| 清丰县| 甘肃省| 太谷县| 盖州市| 巴南区| 泰来县| 大悟县| 阳江市|