千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  應(yīng)聘面試  >  大數(shù)據(jù)面試題  > Flink反壓機(jī)制?

Flink反壓機(jī)制?

來(lái)源:千鋒教育
發(fā)布人:wjy
時(shí)間: 2022-09-02 16:59:16 1662109156

Flink 內(nèi)部是基于producer-consumer模型來(lái)進(jìn)行消息傳遞的,F(xiàn)link的反壓設(shè)計(jì)也是基于這個(gè)模型。

Flink 使用了高效有界的分布式阻塞隊(duì)列,就像 Java 通用的阻塞隊(duì)列(BlockingQueue)一樣。

下游消費(fèi)者消費(fèi)變慢,上游就會(huì)受到阻塞。

Flink反壓機(jī)制?

- Flink 1.5 之前的版本并沒(méi)有對(duì)反壓做特別的處理,它利用buffer來(lái)暫存堆積的無(wú)法處理的數(shù)據(jù),當(dāng) buffer 用滿了,則上游的流阻塞,不再發(fā)送數(shù)據(jù)??梢?jiàn)此時(shí)的反壓是從下游往上游傳播的,一直往上傳播到 Source Task 后,Source Task最終會(huì)降低或提升從外部Source 端讀取數(shù)據(jù)的速率。

這種機(jī)制有一個(gè)比較大的問(wèn)題,在這樣的一個(gè)場(chǎng)景下:同一 Task的不同 SubTask 被安排到同一個(gè) TaskManager,則SubTask與其他TaskManager 的網(wǎng)絡(luò)連接將被多路復(fù)用并共享一個(gè) TCP信道以減少資源使用,所以某個(gè) SubTask產(chǎn)生了反壓的話會(huì)把多路復(fù)用的TCP通道占住,從而會(huì)把其他復(fù)用同一 TCP信道的且沒(méi)有流量壓力的SubTask阻塞。

- Flink1.5版本之后的基于Credit反壓機(jī)制解決了上述問(wèn)題。

這種機(jī)制主要是每次上游SubTask給下游SubTask發(fā)送數(shù)據(jù)時(shí),會(huì)把Buffer中的數(shù)據(jù)和上游ResultSubPartition堆積的數(shù)據(jù)量Backlog size發(fā)給下游,下游會(huì)接收上游發(fā)來(lái)的數(shù)據(jù),并向上游反饋目前下游現(xiàn)在的Credit值,Credit值表示目前下游可以接收上游的Buffer量,1個(gè)Buffer等價(jià)于1個(gè)Credit。

可見(jiàn),這種策略上游向下游發(fā)送數(shù)據(jù)是按需發(fā)送的,而不是和之前一樣會(huì)在公用的Netty和TCP這一層數(shù)據(jù)堆積,避免了影響其他SubTask通信的問(wèn)題。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
內(nèi)部表和外部表(重點(diǎn))

hive外部表是使用external關(guān)鍵字并指定一個(gè)hdfs目錄創(chuàng)建的表。hive內(nèi)部表在創(chuàng)建時(shí)會(huì)在對(duì)應(yīng)hive目錄下創(chuàng)建相應(yīng)的文件夾,外部表則以指定文件夾為...詳情>>

2022-09-02 17:21:00
Flink checkpoint和savepoint區(qū)別

Checkpoint是為runtime準(zhǔn)備的,Savepoint 是為用戶準(zhǔn)備的。Checkpoint 機(jī)制的目標(biāo)在于保證Flink作業(yè)意外崩潰重啟不影響exactly once 準(zhǔn)確性,通...詳情>>

2022-09-02 16:59:22
Flink State?

State:指一個(gè)具體的Task/Operator的狀態(tài)。State可以被記錄,在失敗的情況下數(shù)據(jù)還可以恢復(fù),F(xiàn)link中有兩種基本類型的State: Keyed State, Op...詳情>>

2022-09-02 16:59:19
Flink反壓機(jī)制?

Flink 內(nèi)部是基于producer-consumer模型來(lái)進(jìn)行消息傳遞的,F(xiàn)link的反壓設(shè)計(jì)也是基于這個(gè)模型。Flink 使用了高效有界的分布式阻塞隊(duì)列,就像 Jav...詳情>>

2022-09-02 16:59:16
大數(shù)據(jù)面數(shù)據(jù):Flink Allowed Lateness & Side OutPut?

雖說(shuō)水位線(Watermark)表明早于它的事件不應(yīng)該再出現(xiàn),但是接收到水位線以前的的消息是不可避免的,這就是所謂的遲到事件。實(shí)際上遲到事件是亂...詳情>>

2022-09-02 16:59:00
快速通道