flink異步io應(yīng)用場景之流表join維表

1.flink異步io的定義參考

http://wuchong.me/blog/2017/05/17/flink-internals-async-io/

2.應(yīng)用場景之流表join維表。

流表是kafka等流式數(shù)據(jù)。
維表可以是一個(gè)mysql或者cassandra,redis等存儲(chǔ)微酬,甚至是自己定義的一些api蔫缸。
根據(jù)流表join維表的字段去異步查詢維表渔扎。

3.舉個(gè)例子

流表:kafka id1,id2,id3三列
維表:mysql id,age,name
sql:select id1,id2,id3,age,name from kafka join mysql on id1=id;
join的結(jié)果就是: id1,id2,id3,age,name 流表的字段加上mysql維表的字段盹舞。
流表這邊提供id1像樊,給到維表眷唉,維表那邊執(zhí)行的sql是select * from mysql where id=id1

4.實(shí)戰(zhàn)

參考袋鼠云開源的flinkStreamSQL:

https://github.com/DTStack/flinkStreamSQL
基于開源的flink予颤,對(duì)其實(shí)時(shí)sql進(jìn)行擴(kuò)展;主要實(shí)現(xiàn)了流與維表的join冬阳,支持原生flink SQL所有的語法
源表:kafka 0.9蛤虐,1.x版本
維表:mysql,SQlServer,oracle,hbase肝陪,mongo驳庭,redis,cassandra
結(jié)果表:mysql,SQlServer,oracle,hbase氯窍,elasticsearch5.x饲常,mongo,redis,cassandra

核心是

   AsyncReqRow asyncDbReq = loadAsyncReq(sideType, sqlRootDir, rowTypeInfo, joinInfo, outFieldInfoList, sideTableInfo);

        //TODO How much should be set for the degree of parallelism? Timeout? capacity settings?
        if (ORDERED.equals(sideTableInfo.getCacheMode())){
            return AsyncDataStream.orderedWait(inputStream, asyncDbReq, sideTableInfo.getAsyncTimeout(), TimeUnit.MILLISECONDS, sideTableInfo.getAsyncCapacity())
                    .setParallelism(sideTableInfo.getParallelism());
        }else {
            return AsyncDataStream.unorderedWait(inputStream, asyncDbReq, sideTableInfo.getAsyncTimeout(), TimeUnit.MILLISECONDS, sideTableInfo.getAsyncCapacity())
                    .setParallelism(sideTableInfo.getParallelism());
        }
inputStream 就是我們的流表
loadAsyncReq 就是返回一個(gè)RichAsyncFunction狼讨,定義是

public abstract class AsyncReqRow extends RichAsyncFunction<Row, Row>
就是從維表中查詢數(shù)據(jù)贝淤,目前袋鼠云支持的幾種維表有


image.png

5.擴(kuò)展

流表來源只有kafka,太少熊楼,我們可以擴(kuò)展一下讀取mysql作為流霹娄。參考這里http://www.reibang.com/p/5faa7f822d89

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末能犯,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子犬耻,更是在濱河造成了極大的恐慌踩晶,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,036評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件枕磁,死亡現(xiàn)場離奇詭異渡蜻,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)计济,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門茸苇,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人沦寂,你說我怎么就攤上這事学密。” “怎么了传藏?”我有些...
    開封第一講書人閱讀 164,411評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵腻暮,是天一觀的道長。 經(jīng)常有香客問我毯侦,道長哭靖,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,622評(píng)論 1 293
  • 正文 為了忘掉前任侈离,我火速辦了婚禮试幽,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘卦碾。我一直安慰自己铺坞,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,661評(píng)論 6 392
  • 文/花漫 我一把揭開白布蔗坯。 她就那樣靜靜地躺著康震,像睡著了一般燎含。 火紅的嫁衣襯著肌膚如雪宾濒。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,521評(píng)論 1 304
  • 那天屏箍,我揣著相機(jī)與錄音绘梦,去河邊找鬼。 笑死赴魁,一個(gè)胖子當(dāng)著我的面吹牛卸奉,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播颖御,決...
    沈念sama閱讀 40,288評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼榄棵,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起疹鳄,我...
    開封第一講書人閱讀 39,200評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤拧略,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后瘪弓,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體垫蛆,經(jīng)...
    沈念sama閱讀 45,644評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,837評(píng)論 3 336
  • 正文 我和宋清朗相戀三年腺怯,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了袱饭。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,953評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡呛占,死狀恐怖虑乖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情晾虑,我是刑警寧澤决左,帶...
    沈念sama閱讀 35,673評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站走贪,受9級(jí)特大地震影響佛猛,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜坠狡,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,281評(píng)論 3 329
  • 文/蒙蒙 一继找、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧逃沿,春花似錦婴渡、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,889評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至假消,卻和暖如春柠并,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背富拗。 一陣腳步聲響...
    開封第一講書人閱讀 33,011評(píng)論 1 269
  • 我被黑心中介騙來泰國打工臼予, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人啃沪。 一個(gè)月前我還...
    沈念sama閱讀 48,119評(píng)論 3 370
  • 正文 我出身青樓粘拾,卻偏偏與公主長得像,于是被迫代替她去往敵國和親创千。 傳聞我的和親對(duì)象是個(gè)殘疾皇子缰雇,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,901評(píng)論 2 355

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