【實(shí)戰(zhàn)篇】如何優(yōu)雅的停止你的 Spark Streaming Application

Spark 1.3及其前的版本

你的一個(gè) spark streaming application 已經(jīng)好好運(yùn)行了一段時(shí)間了,這個(gè)時(shí)候你因?yàn)槟撤N原因要停止它。你應(yīng)該怎么做冷溃?直接暴力 kill 該 application 嗎?這可能會(huì)導(dǎo)致數(shù)據(jù)丟失,因?yàn)?receivers 可能已經(jīng)接受到了數(shù)據(jù),但該數(shù)據(jù)還未被處理琳钉,當(dāng)你強(qiáng)行停止該 application,driver 就沒辦法處理這些本該處理的數(shù)據(jù)蛛倦。

所以歌懒,我們應(yīng)該使用一種避免數(shù)據(jù)丟失的方式,官方建議調(diào)用 StreamingContext#stop(stopSparkContext: Boolean, stopGracefully: Boolean)溯壶,將 stopGracefully 設(shè)置為 true及皂,這樣可以保證在 driver 結(jié)束前處理完所有已經(jīng)接受的數(shù)據(jù)。

一個(gè) streaming application 往往是長(zhǎng)時(shí)間運(yùn)行的且改,所以存在兩個(gè)問題:

  1. 應(yīng)該在什么時(shí)候去調(diào)用 StreamingContext#stop
  2. 當(dāng) streaming application 已經(jīng)在運(yùn)行了該怎么去調(diào)用 StreamingContext#stop

how

通過 Runtime.getRuntime().addShutdownHook 注冊(cè)關(guān)閉鉤子验烧, JVM將在關(guān)閉之前執(zhí)行關(guān)閉鉤子中的 run 函數(shù)(不管是正常退出還是異常退出都會(huì)調(diào)用),所以我們可以在 driver 代碼中加入以下代碼:

Runtime.getRuntime().addShutdownHook(new Thread() {
  override def run() {
    log("Shutting down streaming app...")
    streamingContext.stop(true, true)
    log("Shutdown of streaming app complete.")
  }
})

這樣就能保證即使 application 被強(qiáng)行 kill 掉又跛,在 driver 結(jié)束前碍拆,streamingContext.stop(true, true)也會(huì)被調(diào)用,從而保證已接收的數(shù)據(jù)都會(huì)被處理慨蓝。

Spark 1.4及其后的版本

上一小節(jié)介紹的方法僅適用于 1.3及以前的版本感混,在 1.4及其后的版本中不僅不能保證生效,甚至?xí)鹚梨i等線程問題菌仁。在 1.4及其后的版本中浩习,我們只需設(shè)置 spark.streaming.stopGracefullyOnShutdowntrue 即可達(dá)到上一小節(jié)相同的效果。

下面來分析為什么上一小節(jié)介紹的方法在 1.4其后的版本中不能用济丘。首先谱秽,需要明確的是:

  1. 當(dāng)我們注冊(cè)了多個(gè)關(guān)閉鉤子時(shí)洽蛀,JVM開始啟用其關(guān)閉序列時(shí),它會(huì)以某種未指定的順序啟動(dòng)所有已注冊(cè)的關(guān)閉鉤子疟赊,并讓它們同時(shí)運(yùn)行
  2. 萬(wàn)一不止一個(gè)關(guān)閉鉤子郊供,它們將并行地運(yùn)行,并容易引發(fā)線程問題近哟,例如死鎖

綜合以上兩點(diǎn)驮审,我們可以明確,如果除了我們注冊(cè)的關(guān)閉鉤子外吉执,driver 還有注冊(cè)了其他鉤子疯淫,將會(huì)引發(fā)上述兩個(gè)問題。

在 StreamingContext#start 中戳玫,會(huì)調(diào)用

ShutdownHookManager.addShutdownHook(StreamingContext.SHUTDOWN_HOOK_PRIORITY)(stopOnShutdown)

該函數(shù)最終注冊(cè)一個(gè)關(guān)閉鉤子熙掺,并會(huì)在 run 方法中調(diào)用 stopOnShutdown

  private def stopOnShutdown(): Unit = {
    val stopGracefully = conf.getBoolean("spark.streaming.stopGracefullyOnShutdown", false)
    logInfo(s"Invoking stop(stopGracefully=$stopGracefully) from shutdown hook")
    // Do not stop SparkContext, let its own shutdown hook stop it
    stop(stopSparkContext = false, stopGracefully = stopGracefully)
  }

stopOnShutdown 中會(huì)根據(jù) stopGracefully 的值來決定是否以優(yōu)雅的方式結(jié)束 driver咕宿,而 stopGracefully 的值由 spark.streaming.stopGracefullyOnShutdown 決定币绩。結(jié)合上文,也就能說明為什么 spark.streaming.stopGracefullyOnShutdown能決定是否優(yōu)雅的結(jié)束 application 和為什么上一小節(jié)的方法不適用與 1.4及其后版本府阀。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末缆镣,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子试浙,更是在濱河造成了極大的恐慌董瞻,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,968評(píng)論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件川队,死亡現(xiàn)場(chǎng)離奇詭異力细,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)固额,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來煞聪,“玉大人斗躏,你說我怎么就攤上這事∥舾” “怎么了啄糙?”我有些...
    開封第一講書人閱讀 153,220評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)云稚。 經(jīng)常有香客問我隧饼,道長(zhǎng),這世上最難降的妖魔是什么静陈? 我笑而不...
    開封第一講書人閱讀 55,416評(píng)論 1 279
  • 正文 為了忘掉前任燕雁,我火速辦了婚禮诞丽,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘拐格。我一直安慰自己僧免,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,425評(píng)論 5 374
  • 文/花漫 我一把揭開白布捏浊。 她就那樣靜靜地躺著懂衩,像睡著了一般。 火紅的嫁衣襯著肌膚如雪金踪。 梳的紋絲不亂的頭發(fā)上浊洞,一...
    開封第一講書人閱讀 49,144評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音胡岔,去河邊找鬼沛申。 笑死,一個(gè)胖子當(dāng)著我的面吹牛姐军,可吹牛的內(nèi)容都是我干的铁材。 我是一名探鬼主播,決...
    沈念sama閱讀 38,432評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼奕锌,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼著觉!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起惊暴,我...
    開封第一講書人閱讀 37,088評(píng)論 0 261
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤饼丘,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后辽话,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體肄鸽,經(jīng)...
    沈念sama閱讀 43,586評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,028評(píng)論 2 325
  • 正文 我和宋清朗相戀三年油啤,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了典徘。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,137評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡益咬,死狀恐怖逮诲,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情幽告,我是刑警寧澤梅鹦,帶...
    沈念sama閱讀 33,783評(píng)論 4 324
  • 正文 年R本政府宣布,位于F島的核電站冗锁,受9級(jí)特大地震影響齐唆,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜冻河,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,343評(píng)論 3 307
  • 文/蒙蒙 一箍邮、第九天 我趴在偏房一處隱蔽的房頂上張望茉帅。 院中可真熱鬧,春花似錦媒殉、人聲如沸担敌。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)全封。三九已至,卻和暖如春桃犬,著一層夾襖步出監(jiān)牢的瞬間刹悴,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評(píng)論 1 262
  • 我被黑心中介騙來泰國(guó)打工攒暇, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留土匀,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,595評(píng)論 2 355
  • 正文 我出身青樓形用,卻偏偏與公主長(zhǎng)得像就轧,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子田度,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,901評(píng)論 2 345

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