Iceberg新一代數(shù)據(jù)湖技術(shù)實(shí)踐_第1頁(yè)
Iceberg新一代數(shù)據(jù)湖技術(shù)實(shí)踐_第2頁(yè)
Iceberg新一代數(shù)據(jù)湖技術(shù)實(shí)踐_第3頁(yè)
Iceberg新一代數(shù)據(jù)湖技術(shù)實(shí)踐_第4頁(yè)
Iceberg新一代數(shù)據(jù)湖技術(shù)實(shí)踐_第5頁(yè)
已閱讀5頁(yè),還剩14頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、Iceberg在騰訊內(nèi)部的優(yōu)化和實(shí)踐Iceberg新一代數(shù)據(jù)湖技術(shù)數(shù)據(jù)湖技術(shù)Iceberg基本原理Iceberg應(yīng)用落地Flink Iceberg Sink實(shí)現(xiàn)后續(xù)規(guī)劃目錄數(shù)據(jù)湖技術(shù)41什么是數(shù)據(jù)湖存儲(chǔ)集中海量處理方便快速分析統(tǒng)一視圖多種引擎數(shù)據(jù)湖對(duì)比數(shù)據(jù)倉(cāng)庫(kù)數(shù)據(jù)湖數(shù)據(jù)倉(cāng)庫(kù)數(shù)據(jù)來(lái)源社交媒體,移動(dòng)應(yīng)用,傳感器打點(diǎn),業(yè)務(wù)日志關(guān)系型數(shù)據(jù)庫(kù)數(shù)據(jù)類型非結(jié)構(gòu)化,半結(jié)構(gòu)化結(jié)構(gòu)化數(shù)據(jù)質(zhì)量原始,全量加工,挑選Schema在讀取的時(shí)候關(guān) (schema-on-read)變化在規(guī)劃和設(shè)計(jì)階段定義好,為快速 查詢優(yōu)化 (schema-on-write)固定業(yè)務(wù)大數(shù)據(jù)分析,全文檢索,數(shù)據(jù)挖掘,機(jī)器學(xué)習(xí)報(bào)表,展示,商業(yè)智

2、能投入產(chǎn)出基于廉價(jià)的硬件,提供盡可能快的查詢基于昂貴的硬件,提供最快的查詢數(shù)據(jù)湖系統(tǒng)的核心能力數(shù)據(jù)湖數(shù)據(jù)質(zhì)量ACID事務(wù)多種引擎流批一體多種底層存儲(chǔ)元數(shù)據(jù) 可擴(kuò)展數(shù)據(jù)修改數(shù)據(jù)湖技術(shù)三劍客數(shù)據(jù)湖系統(tǒng)的核組件構(gòu)建于存儲(chǔ)系統(tǒng)和文件格式之上的數(shù)據(jù)組織方式保證ACID事務(wù),及一定的并發(fā)能力提供“行”級(jí)別的數(shù)據(jù)修改、刪除的能力確保schema的準(zhǔn)確性,提供“熱”變更能力Iceberg基本原理92Iceberg作為表格式Apache Iceberg is an open table format for huge analytic datasets.Iceberg adds tables to Presto

3、 and Spark that use a high-performance format that works just like a SQL table.Iceberg的核心思想快照(snapshot):在時(shí)間軸上線性的記錄表的所有變化在某一時(shí)刻,表的所有數(shù)據(jù)文件的列表每次更新操作會(huì)生成新的快照,并原子性的commit實(shí)現(xiàn)原子性讀寫分離時(shí)間旅行和版本回滾增量消費(fèi)Iceberg的元數(shù)據(jù)管理元數(shù)據(jù):結(jié)構(gòu) (schema)分區(qū)信息屬性快照歷史記錄分層:HMS或者文件內(nèi)容當(dāng)前的元數(shù)據(jù)JSON文件快照Manifest listManifestData fileS1v1.jsonS1v2.jsonS2

4、Hive MetaStorev0.jsonIceberg應(yīng)用落地133為什么選擇Iceberg優(yōu)化數(shù)據(jù)入庫(kù)流程Iceberg提供ACID事務(wù)能力,上游數(shù)據(jù)寫入即可見,不影 響當(dāng)前數(shù)據(jù)處理任務(wù),這大大簡(jiǎn)化了ETLIceberg提供upsert/merge into 能力,可以極大的縮小 數(shù)據(jù)入庫(kù)延遲支持更多的分析引擎優(yōu)秀的內(nèi)核抽象使之不綁定于特定引擎,目前在支持的 有Spark, Flink, Presto, Hive提供了對(duì)基于流式的增量計(jì)算模型和基于批處理的全量 表計(jì)算模型的支持統(tǒng)一數(shù)據(jù)存儲(chǔ)和靈活的文件組織批任務(wù)和流任務(wù)可以使用相同的存儲(chǔ)模型(文件系統(tǒng),對(duì) 象存儲(chǔ)),數(shù)據(jù)不再孤立。Icebe

5、rg支持隱藏分區(qū)和分區(qū)進(jìn)化,方便業(yè)務(wù)進(jìn)行數(shù)據(jù)分 區(qū)策略更新Parquet, ORC, Avro列存行存兼顧增量處理能力Iceberg支持流式數(shù)據(jù)的落地和增量消費(fèi)Spark Structured Streaming適配Flink sink/source適配基于Iceberg改造數(shù)倉(cāng)的構(gòu)建方式Flink Sink / Spark Structured Streaming write + Iceberg構(gòu)建準(zhǔn)實(shí)時(shí)數(shù)據(jù)接入層Spark DataFrame / SQL進(jìn)行數(shù)據(jù)修正Flink source / Spark Structured Streaming read進(jìn)行增量消費(fèi)Spark / Hiv

6、e / Presto進(jìn)行交互式查詢Flink Iceberg Sink實(shí)現(xiàn)164Flink sink的基本原理組件類型功能并行WriterStreamOperator累積上游數(shù)據(jù)在checkpoint時(shí)發(fā)送barrier之前flush DataFile,并向下游發(fā)送 DataFile信息是CommitterSinkFunction接收上游的DataFile信息;在checkpoint時(shí)把DataFile信息填入Manifest,并把Manifest寫入 state在checkpoint成功后向Iceberg commit否后續(xù)規(guī)劃185Flink Iceberg Sink后續(xù)規(guī)劃融入內(nèi)部平臺(tái)和系統(tǒng),提高易用性,釋放Iceb

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論