[zebra源碼]GroupDataSource讀庫(kù)的負(fù)載均衡

GroupDataSource的物理結(jié)構(gòu)


image.png

負(fù)載均衡的對(duì)象

zebra的負(fù)載均衡是在GroupDataSource的讀庫(kù) readDataSource( LoadBalanceDataSource) 中進(jìn)行的, 它內(nèi)部包含多個(gè)讀庫(kù)節(jié)點(diǎn)的SingleDataSource

LoadBalanceDataSource#getConnection() -> router.select(context);

關(guān)鍵對(duì)象DataSourceRouter 數(shù)據(jù)源路由器

負(fù)載均衡由 DataSourceRouter 數(shù)據(jù)源路由器實(shí)現(xiàn)具體的邏輯 => 它是個(gè)套娃

image.png

包含 中心路由、idc路由撕蔼、區(qū)域路由和權(quán)重乾戏, 這幾個(gè)負(fù)載均衡算法是嵌套執(zhí)行的, 從范圍大到小逐層進(jìn)行

默認(rèn)的 routerStrategy=“WeightRouter" 即 WeightDataSourceRouter 在最里層同機(jī)房范圍內(nèi)的多個(gè)讀庫(kù)是根據(jù)權(quán)重來(lái)選擇的


image.png

了解更多比肄,官方文檔 zebra路由設(shè)計(jì)

區(qū)域夹抗、中心、機(jī)房酸员,最后都會(huì)走向基于權(quán)重的路由 WeightDataSourceRouter#select()

public RouterTarget select(Set<RouterTarget> excludeTargets) {
    if (!this.targets.isEmpty()) {
        TreeSet<RouterTarget> weights = this.targets;
        int tmpGroupDataSourceTargetSize = this.groupDataSourceTargetSize;

        if (excludeTargets != null && !excludeTargets.isEmpty()) {
            // 需要排除某些GroupDataSourceTarget的話匈子,就重新copy一個(gè)weights
            TreeSet<RouterTarget> copyWeights = new TreeSet<RouterTarget>();
            tmpGroupDataSourceTargetSize = 0;
            for (RouterTarget routerTarget : weights) {
                if (excludeTargets.contains(routerTarget)) {
                    continue;
                }
                // 先將節(jié)點(diǎn)先放入到排序集合中
                // 假設(shè)  節(jié)點(diǎn)1 -> weight=2, 節(jié)點(diǎn)2 -> weight=3
                // 則在排序樹(shù)中 節(jié)點(diǎn)1 -> sort=2, 節(jié)點(diǎn)2 -> sort = 2+3
                int weight = routerTarget.getWeight();
                tmpGroupDataSourceTargetSize += weight;
                copyWeights.add(new RouterTarget(routerTarget.getId(), weight, tmpGroupDataSourceTargetSize - 1));
            }
            weights = copyWeights;
        }

        if (weights.isEmpty() || tmpGroupDataSourceTargetSize <= 0) {
            return null;
        }
        // 取一個(gè)隨機(jī)數(shù)
        int randomNum = random.nextInt(tmpGroupDataSourceTargetSize);
        RouterTarget tempForSearch = new RouterTarget(null, -1, randomNum);
        //排序集合中最靠近隨機(jī)數(shù)的entry則為目標(biāo)節(jié)點(diǎn)
        return weights.ceiling(tempForSearch);
    } else {
        return null;
    }
}
}

想要查看具體執(zhí)行細(xì)節(jié) 河胎,可以debug 源碼里 com.dianping.zebra.group.router 包下的 DataSourceRouter 單測(cè)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市虎敦,隨后出現(xiàn)的幾起案子游岳,更是在濱河造成了極大的恐慌,老刑警劉巖其徙,帶你破解...
    沈念sama閱讀 217,509評(píng)論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件胚迫,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡唾那,警方通過(guò)查閱死者的電腦和手機(jī)访锻,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)闹获,“玉大人期犬,你說(shuō)我怎么就攤上這事”芊蹋” “怎么了龟虎?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,875評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)沙庐。 經(jīng)常有香客問(wèn)我鲤妥,道長(zhǎng),這世上最難降的妖魔是什么拱雏? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,441評(píng)論 1 293
  • 正文 為了忘掉前任棉安,我火速辦了婚禮,結(jié)果婚禮上铸抑,老公的妹妹穿的比我還像新娘辆它。我一直安慰自己偿衰,他們只是感情好芯砸,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,488評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布唠梨。 她就那樣靜靜地躺著,像睡著了一般柒昏。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上熙揍,一...
    開(kāi)封第一講書(shū)人閱讀 51,365評(píng)論 1 302
  • 那天职祷,我揣著相機(jī)與錄音,去河邊找鬼。 笑死有梆,一個(gè)胖子當(dāng)著我的面吹牛是尖,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播泥耀,決...
    沈念sama閱讀 40,190評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼饺汹,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了痰催?” 一聲冷哼從身側(cè)響起兜辞,我...
    開(kāi)封第一講書(shū)人閱讀 39,062評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎夸溶,沒(méi)想到半個(gè)月后逸吵,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,500評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡缝裁,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,706評(píng)論 3 335
  • 正文 我和宋清朗相戀三年扫皱,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片捷绑。...
    茶點(diǎn)故事閱讀 39,834評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡韩脑,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出粹污,到底是詐尸還是另有隱情段多,我是刑警寧澤,帶...
    沈念sama閱讀 35,559評(píng)論 5 345
  • 正文 年R本政府宣布厕怜,位于F島的核電站衩匣,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏粥航。R本人自食惡果不足惜琅捏,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,167評(píng)論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望递雀。 院中可真熱鬧柄延,春花似錦、人聲如沸缀程。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,779評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)杨凑。三九已至滤奈,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間撩满,已是汗流浹背蜒程。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,912評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工绅你, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人昭躺。 一個(gè)月前我還...
    沈念sama閱讀 47,958評(píng)論 2 370
  • 正文 我出身青樓忌锯,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親领炫。 傳聞我的和親對(duì)象是個(gè)殘疾皇子偶垮,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,779評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容