flink使用11-了解broadcast的用法

在Flink中吁伺,同一個算子可能存在若干個不同的并行實例矩肩,計算過程可能不在同一個Slot中進行秸谢,不同算子之間更是如此靠抑,因此不同算子的計算數(shù)據(jù)之間不能像Java數(shù)組之間一樣互相訪問量九,而廣播變量Broadcast便是解決這種情況的. 在 flink 中, 針對某一個算子需要使用公共變量的情況下, 就可以把對應(yīng)的數(shù)據(jù)給廣播出去, 這樣在所有的節(jié)點中都可以使用了. 典型的代碼結(jié)構(gòu)如下所示:

在一個算子中使用廣播變量主要有兩個步驟:

  1. 廣播變量 (一般寫在算子的后面即可)

    使用 withBroadcastSet(data, "name") 這個方法即可, name變量代表了獲取該廣播變量的名稱

  2. 使用廣播變量

    使用方法主要是通過 RichFunction, 在 對應(yīng)的 open( )方法中, 可以根據(jù)名稱來獲取對應(yīng)的廣播變量, 只需要一次獲取, 就可以一直使用了, 具體方法如下:


dataSet.map(new RichMapFunction<String, String>() {
            List<Integer> bc;
            @Override
            public void open(Configuration parameters) throws Exception {
                super.open(parameters);
                // 2. 獲取廣播變量
                this.bc = getRuntimeContext().getBroadcastVariable("broadcastData");
            }
            @Override
            public String map(String s) throws Exception {
                return s;
            }
        // 1. 將需要用的變量廣播出去 (這一步可以寫在后面)
        }).withBroadcastSet(broadcastData, "broadcastData").print();

下面以一個獲取用戶年齡的例子來演示一個常見的使用案例:

broadcastData 是一個包含用戶 (姓名, 年齡) 的數(shù)據(jù)表

需要在另外一個算子中通過姓名查找年齡, 那么就需要把上表廣播

public class BroadcastExample {

    public static void main(String[] args) throws Exception {


        ExecutionEnvironment env = ExecutionEnvironment.getExecutionEnvironment();
        env.setParallelism(4);

        // 創(chuàng)建需要廣播的 數(shù)據(jù)集 (name, age)
        Tuple2<String, Integer> john = new Tuple2<>("john", 23);
        Tuple2<String, Integer> tom = new Tuple2<>("tom", 24);
        Tuple2<String, Integer> shiny = new Tuple2<>("shiny", 22);
        DataSource<Tuple2<String, Integer>> broadcastData = env.fromElements(john, tom, shiny);

        // 新建一個dataset -> d1, 設(shè)置并行度為4
        // 此時 d1 是無法訪問 broadcastData 的數(shù)據(jù)的, 因為兩個dataset可能不在一個節(jié)點或者slot中, 所以 flink 是不允許去訪問的
        DataSet<String> d1 = env.fromElements("john", "tom", "shiny").setParallelism(4);

        // 使用 RichMapFunction, 在open() 方法中拿到廣播變量
        d1.map(new RichMapFunction<String, String>() {
            List<Tuple2<String, Integer>> bc;
            HashMap<String, Integer> map = new HashMap<>();
            @Override
            public void open(Configuration parameters) throws Exception {
                super.open(parameters);
                this.bc = getRuntimeContext().getBroadcastVariable("broadcastData");
                for (Tuple2<String, Integer> tp : bc) {
                    this.map.put(tp.f0, tp.f1);
                }
            }
            @Override
            public String map(String s) throws Exception {
                Integer age = this.map.get(s);
                return s + "->" + age;
            }
        }).withBroadcastSet(broadcastData, "broadcastData").print();
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市孕荠,隨后出現(xiàn)的幾起案子娩鹉,更是在濱河造成了極大的恐慌,老刑警劉巖稚伍,帶你破解...
    沈念sama閱讀 206,839評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件弯予,死亡現(xiàn)場離奇詭異,居然都是意外死亡个曙,警方通過查閱死者的電腦和手機锈嫩,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來垦搬,“玉大人呼寸,你說我怎么就攤上這事『锓。” “怎么了对雪?”我有些...
    開封第一講書人閱讀 153,116評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長米绕。 經(jīng)常有香客問我瑟捣,道長,這世上最難降的妖魔是什么栅干? 我笑而不...
    開封第一講書人閱讀 55,371評論 1 279
  • 正文 為了忘掉前任迈套,我火速辦了婚禮,結(jié)果婚禮上碱鳞,老公的妹妹穿的比我還像新娘桑李。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 64,384評論 5 374
  • 文/花漫 我一把揭開白布贵白。 她就那樣靜靜地躺著率拒,像睡著了一般。 火紅的嫁衣襯著肌膚如雪戒洼。 梳的紋絲不亂的頭發(fā)上俏橘,一...
    開封第一講書人閱讀 49,111評論 1 285
  • 那天,我揣著相機與錄音圈浇,去河邊找鬼。 笑死靴寂,一個胖子當(dāng)著我的面吹牛磷蜀,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播百炬,決...
    沈念sama閱讀 38,416評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼褐隆,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了剖踊?” 一聲冷哼從身側(cè)響起庶弃,我...
    開封第一講書人閱讀 37,053評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎德澈,沒想到半個月后歇攻,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,558評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡梆造,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,007評論 2 325
  • 正文 我和宋清朗相戀三年缴守,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片镇辉。...
    茶點故事閱讀 38,117評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡屡穗,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出忽肛,到底是詐尸還是另有隱情村砂,我是刑警寧澤,帶...
    沈念sama閱讀 33,756評論 4 324
  • 正文 年R本政府宣布屹逛,位于F島的核電站础废,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏煎源。R本人自食惡果不足惜色迂,卻給世界環(huán)境...
    茶點故事閱讀 39,324評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望手销。 院中可真熱鬧歇僧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至侥钳,卻和暖如春适袜,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背舷夺。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評論 1 262
  • 我被黑心中介騙來泰國打工苦酱, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人给猾。 一個月前我還...
    沈念sama閱讀 45,578評論 2 355
  • 正文 我出身青樓疫萤,卻偏偏與公主長得像,于是被迫代替她去往敵國和親敢伸。 傳聞我的和親對象是個殘疾皇子扯饶,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,877評論 2 345

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