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

請輸入評論內(nèi)容...
請輸入評論/評論長度6~500個字
最新活動更多
-
8月5日立即報名>> 【在線會議】CAE優(yōu)化設(shè)計:醫(yī)療器械設(shè)計的應(yīng)用案例與方案解析
-
8月14日立即報名>> 【在線研討會】解析安森美(onsemi)高精度與超低功耗CGM系統(tǒng)解決方案
-
精彩回顧立即查看>> 《2024智能制造產(chǎn)業(yè)高端化、智能化、綠色化發(fā)展藍皮書》
-
精彩回顧立即查看>> 7月30日- 8月1日 2025全數(shù)會工業(yè)芯片與傳感儀表展
-
精彩回顧立即查看>> 全數(shù)會2025(第六屆)機器人及智能工廠展
-
精彩回顧立即查看>> OFweek 2025 具身機器人動力電池技術(shù)應(yīng)用大會
推薦專題
- 1 AI產(chǎn)業(yè)的新高度!英偉達成為全球首家市值破4萬億美元的公司
- 2 傳魏建軍與賈躍亭合作,長城汽車出海美國
- 3 一文讀懂:到底什么是 “具身智能” ?
- 4 黃仁勛:與雷軍長期合作,共探AI智駕
- 5 具身智能泡沫爭議下,華映資本尋找「穿越周期者」
- 6 中國平安們欲靠AI守“陣地”
- 7 官宣:智元機器人借殼上市,A股人形機器人第一股!
- 8 華為讓渡“三界”銷售主導(dǎo)權(quán),智界高管:終于能全力奔跑了
- 9 借仿生手實現(xiàn)突圍,國產(chǎn)靈巧手破局“不可能三角”
- 10 DeepSeek R2加持,中國AI與芯片產(chǎn)業(yè)迎來新一輪協(xié)同進化