六保礼、RocketMQ-Producer-Send深入一丟丟

一、概述

本篇主要跟蹤下producer的發(fā)送流程责语,以SYNC同步模式為例炮障,假定producer已經(jīng)start了

二、主線流程圖

主線流程圖

三坤候、流程深入一丟丟

再次說明下胁赢,這里是以SYNC為例子
只對邏輯相對較多的幾個方法做講解

方法2:

增加了一個timeout,發(fā)送超時時間白筹,默認時間 3 秒

SendResult send(Message msg,long timeout)

方法3:sendDefaultImpl()

方法流程圖

方法內(nèi)智末,會根據(jù)策略獲取待發(fā)送的隊列谅摄,然后調(diào)用sendKernelImpl發(fā)送消息,如果發(fā)送失敗系馆,會嘗試 1 + 重試次數(shù)(默認為2) = 3次

方法4 sendKernelImpl()

sendKernelImpl
  • 首先為消息添加主鍵送漠,格式如下:
    UNIQ_KEY : 0BCDF1716BEC18B4AAC27F26B89A0000
  • 壓縮消息
  • 執(zhí)行hookbefore方法(如果有的話)
  • 組織requestHeader作為下個方法的參數(shù)

方法6 invokeSync

這個方法在調(diào)用 invokeSyncImpl 的前后,分別調(diào)用了doBeforeRpcHooksdoAfterRpcHooks的hooks方法由蘑,切入RPC調(diào)用

方法7 invokeSyncImpl

這個是最終和broker通訊的代碼闽寡,通過netty的channel.writeAndFlush(request)方法將消息發(fā)送給broker,并通過ChannelFutureListener回調(diào)函數(shù)獲取broker的反饋
通過下面的代碼讓阻塞線程尼酿,其實內(nèi)部就是一個length=1的CountDownLatch

RemotingCommand responseCommand = responseFuture.waitResponse(timeoutMillis);

然后在ChannelFutureListener回調(diào)函數(shù)的putResponse方法中釋放爷狈,latch - 1,保證獲取到回饋再返回
具體的源代碼如下:

public RemotingCommand invokeSyncImpl(final Channel channel, final RemotingCommand request,
        final long timeoutMillis)
        throws InterruptedException, RemotingSendRequestException, RemotingTimeoutException {
        final int opaque = request.getOpaque();

        try {
            final ResponseFuture responseFuture = new ResponseFuture(channel, opaque, timeoutMillis, null, null);
            this.responseTable.put(opaque, responseFuture);
            final SocketAddress addr = channel.remoteAddress();
            channel.writeAndFlush(request).addListener(new ChannelFutureListener() {
                @Override
                public void operationComplete(ChannelFuture f) throws Exception {
                    if (f.isSuccess()) {
                        responseFuture.setSendRequestOK(true);
                        return;
                    } else {
                        responseFuture.setSendRequestOK(false);
                    }

                    responseTable.remove(opaque);
                    responseFuture.setCause(f.cause());
                    responseFuture.putResponse(null);
                    log.warn("send a request command to channel <" + addr + "> failed.");
                }
            });
            // 在這里阻塞 等待響應(yīng)
            RemotingCommand responseCommand = responseFuture.waitResponse(timeoutMillis);
            if (null == responseCommand) {
                if (responseFuture.isSendRequestOK()) {
                    throw new RemotingTimeoutException(RemotingHelper.parseSocketAddressAddr(addr), timeoutMillis,
                        responseFuture.getCause());
                } else {
                    throw new RemotingSendRequestException(RemotingHelper.parseSocketAddressAddr(addr), responseFuture.getCause());
                }
            }

            return responseCommand;
        } finally {
            this.responseTable.remove(opaque);
        }
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末谓媒,一起剝皮案震驚了整個濱河市淆院,隨后出現(xiàn)的幾起案子何乎,更是在濱河造成了極大的恐慌句惯,老刑警劉巖,帶你破解...
    沈念sama閱讀 210,978評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件支救,死亡現(xiàn)場離奇詭異抢野,居然都是意外死亡,警方通過查閱死者的電腦和手機各墨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評論 2 384
  • 文/潘曉璐 我一進店門指孤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人贬堵,你說我怎么就攤上這事恃轩。” “怎么了黎做?”我有些...
    開封第一講書人閱讀 156,623評論 0 345
  • 文/不壞的土叔 我叫張陵叉跛,是天一觀的道長。 經(jīng)常有香客問我蒸殿,道長筷厘,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,324評論 1 282
  • 正文 為了忘掉前任宏所,我火速辦了婚禮酥艳,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘爬骤。我一直安慰自己充石,他們只是感情好,可當我...
    茶點故事閱讀 65,390評論 5 384
  • 文/花漫 我一把揭開白布霞玄。 她就那樣靜靜地躺著骤铃,像睡著了一般浓镜。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上劲厌,一...
    開封第一講書人閱讀 49,741評論 1 289
  • 那天膛薛,我揣著相機與錄音,去河邊找鬼补鼻。 笑死哄啄,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的风范。 我是一名探鬼主播咨跌,決...
    沈念sama閱讀 38,892評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼硼婿!你這毒婦竟也來了锌半?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,655評論 0 266
  • 序言:老撾萬榮一對情侶失蹤寇漫,失蹤者是張志新(化名)和其女友劉穎刊殉,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體州胳,經(jīng)...
    沈念sama閱讀 44,104評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡记焊,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了栓撞。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片遍膜。...
    茶點故事閱讀 38,569評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖瓤湘,靈堂內(nèi)的尸體忽然破棺而出瓢颅,到底是詐尸還是另有隱情,我是刑警寧澤弛说,帶...
    沈念sama閱讀 34,254評論 4 328
  • 正文 年R本政府宣布挽懦,位于F島的核電站,受9級特大地震影響剃浇,放射性物質(zhì)發(fā)生泄漏巾兆。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,834評論 3 312
  • 文/蒙蒙 一虎囚、第九天 我趴在偏房一處隱蔽的房頂上張望角塑。 院中可真熱鬧,春花似錦淘讥、人聲如沸圃伶。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽窒朋。三九已至搀罢,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間侥猩,已是汗流浹背榔至。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留欺劳,地道東北人唧取。 一個月前我還...
    沈念sama閱讀 46,260評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像划提,于是被迫代替她去往敵國和親枫弟。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,446評論 2 348