老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業(yè)提供網(wǎng)站建設、域名注冊、服務器等服務

DStreams上的輸出操作是怎樣的

本篇文章給大家分享的是有關DStreams上的輸出操作是怎樣的,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

成都創(chuàng)新互聯(lián)長期為上1000家客戶提供的網(wǎng)站建設服務,團隊從業(yè)經(jīng)驗10年,關注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務;打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為黑山企業(yè)提供專業(yè)的網(wǎng)站設計、成都網(wǎng)站建設,黑山網(wǎng)站改版等技術服務。擁有十年豐富建站經(jīng)驗和眾多成功案例,為您定制開發(fā)。

dstream.foreachRDD是一個強大的原語,發(fā)送數(shù)據(jù)到外部系統(tǒng)中。然而,明白怎樣正確地、有效地用這個原語是非常重要的。下面幾點介紹了如何避免一般錯誤。

  • 經(jīng)常寫數(shù)據(jù)到外部系統(tǒng)需要建一個連接對象(例如到遠程服務器的TCP連接),用它發(fā)送數(shù)據(jù)到遠程系統(tǒng)。為了達到這個目的,開發(fā)人員可能不經(jīng)意的在Spark驅動中創(chuàng)建一個連接對象,但是在Spark worker中 嘗試調(diào)用這個連接對象保存記錄到RDD中,如下:

 dstream.foreachRDD(rdd => {      val connection = createNewConnection()  // executed at the driver
      rdd.foreach(record => {
          connection.send(record) // executed at the worker
      })
  })

這是不正確的,因為這需要先序列化連接對象,然后將它從driver發(fā)送到worker中。這樣的連接對象在機器之間不能傳送。它可能表現(xiàn)為序列化錯誤(連接對象不可序列化)或者初始化錯誤(連接對象應該 在worker中初始化)等等。正確的解決辦法是在worker中創(chuàng)建連接對象。

  • 然而,這會造成另外一個常見的錯誤-為每一個記錄創(chuàng)建了一個連接對象。例如:

dstream.foreachRDD(rdd => {
      rdd.foreach(record => {
          val connection = createNewConnection()
          connection.send(record)
          connection.close()
      })
  })

通常,創(chuàng)建一個連接對象有資源和時間的開支。因此,為每個記錄創(chuàng)建和銷毀連接對象會導致非常高的開支,明顯的減少系統(tǒng)的整體吞吐量。一個更好的解決辦法是利用rdd.foreachPartition方法。 為RDD的partition創(chuàng)建一個連接對象,用這個兩件對象發(fā)送partition中的所有記錄。

dstream.foreachRDD(rdd => {
      rdd.foreachPartition(partitionOfRecords => {
          val connection = createNewConnection()
          partitionOfRecords.foreach(record => connection.send(record))
          connection.close()
      })
  })

這就將連接對象的創(chuàng)建開銷分攤到了partition的所有記錄上了。

  • 最后,可以通過在多個RDD或者批數(shù)據(jù)間重用連接對象做更進一步的優(yōu)化。開發(fā)者可以保有一個靜態(tài)的連接對象池,重復使用池中的對象將多批次的RDD推送到外部系統(tǒng),以進一步節(jié)省開支。

dstream.foreachRDD(rdd => {
      rdd.foreachPartition(partitionOfRecords => {
          // ConnectionPool is a static, lazily initialized pool of connections
          val connection = ConnectionPool.getConnection()
          partitionOfRecords.foreach(record => connection.send(record))
          ConnectionPool.returnConnection(connection)  // return to the pool for future reuse
      })
  })

需要注意的是,池中的連接對象應該根據(jù)需要延遲創(chuàng)建,并且在空閑一段時間后自動超時。這樣就獲取了最有效的方式發(fā)生數(shù)據(jù)到外部系統(tǒng)。

其它需要注意的地方:

  • 輸出操作通過懶執(zhí)行的方式操作DStreams,正如RDD action通過懶執(zhí)行的方式操作RDD。具體地看,RDD actions和DStreams輸出操作接收數(shù)據(jù)的處理。因此,如果你的應用程序沒有任何輸出操作或者 用于輸出操作dstream.foreachRDD(),但是沒有任何RDD action操作在dstream.foreachRDD()里面,那么什么也不會執(zhí)行。系統(tǒng)僅僅會接收輸入,然后丟棄它們。

  • 默認情況下,DStreams輸出操作是分時執(zhí)行的,它們按照應用程序的定義順序按序執(zhí)行。

以上就是DStreams上的輸出操作是怎樣的,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降摹OM隳芡ㄟ^這篇文章學到更多知識。更多詳情敬請關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


當前文章:DStreams上的輸出操作是怎樣的
網(wǎng)站網(wǎng)址:http://www.xueling.net.cn/article/pgihho.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP
主站蜘蛛池模板: 色综合999 | 亚洲国产精品一区二区九九 | 狠狠做深爱婷婷久久综合一区 | av私库在线 | 国产精品无码AV一区二区三区 | 潮喷失禁大喷水aⅴ无码 | 狠狠色狠狠色狠狠五月 | 国产精品尹人在线观看 | a狠狠久久蜜臀婷色中文网 爱999精品视频 | 日本三级日本三级日本三级极 | 青草在线视频 | 日本做暖暖视频高清观看 | 新包青天1995国语版 | www.欧美视频 | 一本一道色欲综合网 | 99热久久久久久久久久久174 | 免费国产小视频 | 欧美久久国产精品 | 十次啦综合中文亚洲 | 麻豆人妻无码性色av专区 | 亚洲国产成人精品无码区99 | 免费视频网站在线 | 成年性羞羞视频免费观看无限 | 韩国三级激情吃奶 | 国产精品人人爽人人爽av | 久久精品噜噜噜成人88aⅴ | 欧美国产成人久久精品 | 成人av影片在线观看 | 欧美高清FREEXXXX性 | 香蕉视频网站在线观看 | 国产一区二区三区免费在线观看 | 亚洲网址| 亚洲国产成人丁香五月激情 | 自拍视频在线播放 | 日韩永久免费 | 最近2018中文字幕免费看手机 | 精品一区二区视频 | 国产精品久久人妻拍拍水牛影视 | 一级毛片不卡顿 | 国产视频二区在线观看 | 暗呦交小u女国产精品视频 国产精品99无码一区二区 |