GreenPlum數(shù)據(jù)分布機(jī)制
一、介紹
GreenPlum是Coodinator/Segment架構(gòu),集群通常由一個(gè)Coodinator節(jié)點(diǎn)和一個(gè)standby coodinator節(jié)點(diǎn)以及多個(gè)segment節(jié)點(diǎn)組成,其中數(shù)據(jù)放置在segment節(jié)點(diǎn)上。Coodinator是整個(gè)數(shù)據(jù)庫(kù)的入口,客戶端只會(huì)連接到Coodinator上并執(zhí)行相關(guān)查詢操作,Standby節(jié)點(diǎn)為Coordinator提供高可用支持,Mirror為primary的備。
數(shù)據(jù)默認(rèn)使用hash分布。
二、插入時(shí)數(shù)據(jù)是如何分布分發(fā)到哪個(gè)segment?
1、插入操作時(shí)值的由來(lái)
我們看下insert語(yǔ)句的執(zhí)行計(jì)劃:
它沒(méi)有Motion節(jié)點(diǎn),僅1個(gè)slice,即root slice。Result節(jié)點(diǎn)是將insert的值物化以構(gòu)建TupleTableSlot進(jìn)行插入。也就是先物化然后insert。
這里主要關(guān)注物化的值從哪來(lái)。Result節(jié)點(diǎn)的執(zhí)行堆棧為:
ExecInterpExpr計(jì)算物化值步驟:EEOP_CONST;EEOP_ASSIGN_TMP。也就是得到個(gè)常量值放到resultslot中。
通過(guò)gdb跟蹤每個(gè)segment進(jìn)程,可以了解到這里的常量值就是INSERT語(yǔ)句中VALUES的值。
此時(shí)就可以了解到,SQL語(yǔ)句中VALUES值是直接發(fā)送到對(duì)于的segment的。
那么,具體是如何發(fā)送的呢?
2、值的發(fā)送
發(fā)送函數(shù)由cdbdisp_dispatchX完成。我們來(lái)跟蹤這個(gè)函數(shù),看下是如何分發(fā)到指定的segment的。
了解GP原理的話,我們知道發(fā)送前需要先在master和segment之間建立一個(gè)連接,然后將執(zhí)行計(jì)劃通過(guò)這個(gè)連接發(fā)送過(guò)去。建立連接就是創(chuàng)建Gang,由函數(shù)AssignGangs完成。
最終創(chuàng)建Gang建立連接會(huì)調(diào)用函數(shù)cdbgang_createGang_async。下面我們看下這個(gè)函數(shù)是如何建立連接的。
cdbconn_doConnectStart連接時(shí),SegmentDatabaseDescriptor segdbDesc中的segment_database_info::GpSegConfigEntry存有segment的端口及IP等信息,即gp_segment_configuration系統(tǒng)表中內(nèi)容;诖诵畔ⅲ梢越⑦B接。
那么segdbDesc內(nèi)容從何而來(lái)?
從上述堆棧,segdbDesc是Gang中的db_descriptors[i],也就是buildGangDefinition函數(shù)生成:
SliceTable.slices[0].segments為入?yún)egments鏈表,存儲(chǔ)著執(zhí)行該slice的所有segment的content id。segdbDesc是根據(jù)content id從系統(tǒng)表gp_segment_config來(lái)獲取。
到這里可以知道,通過(guò)SliceTable中的segment鏈表得到該slice的segment的content。Insert僅一個(gè)slice,insert分發(fā)到執(zhí)行該insert的segment,content就是該segment的content id。通過(guò)該content id從gp_segment_configuration系統(tǒng)表中得到相關(guān)port、IP等信息,從而據(jù)此在master和segment之間建立連接。構(gòu)建鏈接后,insert語(yǔ)句通過(guò)此鏈接發(fā)送到對(duì)應(yīng)的segment。
那么content id又是如何與分布鍵聯(lián)系起來(lái)呢?
經(jīng)過(guò)分析,由函數(shù)DirectDispatchUpdateContentIdsForInsert來(lái)完成映射:
constvalue為分布鍵的key值,然后通過(guò)cdbhash函數(shù)通過(guò)系統(tǒng)hash函數(shù)將key值進(jìn)行hash,最終得到hashcode,該值即為content id,放到contentIds鏈表中。
三、基礎(chǔ)知識(shí)1、gp_segment_configuration
2、Gang、slice與QueryDesc之間關(guān)系
原文標(biāo)題 : GreenPlum數(shù)據(jù)分布機(jī)制

發(fā)表評(píng)論
請(qǐng)輸入評(píng)論內(nèi)容...
請(qǐng)輸入評(píng)論/評(píng)論長(zhǎng)度6~500個(gè)字
圖片新聞
-
馬云重返一線督戰(zhàn),阿里重啟創(chuàng)始人模式
-
機(jī)器人奧運(yùn)會(huì)戰(zhàn)報(bào):宇樹(shù)機(jī)器人摘下首金,天工Ultra搶走首位“百米飛人”
-
存儲(chǔ)圈掐架!江波龍起訴佰維,索賠121萬(wàn)
-
長(zhǎng)安汽車母公司突然更名:從“中國(guó)長(zhǎng)安”到“辰致科技”
-
豆包前負(fù)責(zé)人喬木出軌BP后續(xù):均被辭退
-
字節(jié)AI Lab負(fù)責(zé)人李航卸任后返聘,Seed進(jìn)入調(diào)整期
-
員工持股爆雷?廣汽埃安緊急回應(yīng)
-
中國(guó)“智造”背后的「關(guān)鍵力量」
最新活動(dòng)更多
-
10月23日火熱報(bào)名中>> 2025是德科技創(chuàng)新技術(shù)峰會(huì)
-
10月23日立即報(bào)名>> Works With 開(kāi)發(fā)者大會(huì)深圳站
-
10月24日立即參評(píng)>> 【評(píng)選】維科杯·OFweek 2025(第十屆)物聯(lián)網(wǎng)行業(yè)年度評(píng)選
-
即日-11.25立即下載>>> 費(fèi)斯托白皮書(shū)《柔性:汽車生產(chǎn)未來(lái)的關(guān)鍵》
-
11月27日立即報(bào)名>> 【工程師系列】汽車電子技術(shù)在線大會(huì)
-
12月18日立即報(bào)名>> 【線下會(huì)議】OFweek 2025(第十屆)物聯(lián)網(wǎng)產(chǎn)業(yè)大會(huì)
推薦專題
-
8 每日AI全球觀察
- 1 特斯拉工人被故障機(jī)器人打成重傷,索賠3.6億
- 2 【行業(yè)深度研究】退居幕后四年后,張一鳴終于把算法公司變成AI公司?
- 3 AI 時(shí)代,阿里云想當(dāng)“安卓” ,那誰(shuí)是“蘋果”?
- 4 拐點(diǎn)已至!匯川領(lǐng)跑工控、埃斯頓份額第一、新時(shí)達(dá)海爾賦能扭虧為盈
- 5 硬剛英偉達(dá)!華為發(fā)布全球最強(qiáng)算力超節(jié)點(diǎn)和集群
- 6 隱退4年后,張一鳴久違現(xiàn)身!互聯(lián)網(wǎng)大佬正集體殺回
- 7 00后華裔女生靠?jī)刹緼I電影狂賺7.8億人民幣,AI正式進(jìn)軍好萊塢
- 8 谷歌“香蕉”爆火啟示:國(guó)產(chǎn)垂類AI的危機(jī)還是轉(zhuǎn)機(jī)?
- 9 機(jī)器人9月大事件|3家國(guó)產(chǎn)機(jī)器人沖刺IPO,行業(yè)交付與融資再創(chuàng)新高!
- 10 美光:AI Capex瘋投不止,終于要拉起存儲(chǔ)超級(jí)周期了?
- 生產(chǎn)部總監(jiān) 廣東省/廣州市
- 資深管理人員 廣東省/江門市
- Regional Sales Manager 廣東省/深圳市
- 銷售總監(jiān) 廣東省/深圳市
- 結(jié)構(gòu)工程師 廣東省/深圳市
- 光器件研發(fā)工程師 福建省/福州市
- 自動(dòng)化高級(jí)工程師 廣東省/深圳市
- 技術(shù)專家 廣東省/江門市
- 激光器高級(jí)銷售經(jīng)理 上海市/虹口區(qū)
- 封裝工程師 北京市/海淀區(qū)