欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

如何進(jìn)行JobScheduler內(nèi)幕實(shí)現(xiàn)和深度思考

本篇文章為大家展示了如何進(jìn)行JobScheduler內(nèi)幕實(shí)現(xiàn)和深度思考,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供五華網(wǎng)站建設(shè)、五華做網(wǎng)站、五華網(wǎng)站設(shè)計(jì)、五華網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計(jì)與制作、五華企業(yè)網(wǎng)站模板建站服務(wù),十多年五華做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。

DStream的foreachRDD方法,實(shí)例化ForEachDStream對象,并將用戶定義的函數(shù)foreachFunc傳入到該對象中。foreachRDD方法是輸出操作,foreachFunc方法會作用到這個DStream中的每個RDD。

/**
 * Apply a function to each RDD in this DStream. This is an output operator, so
 * 'this' DStream will be registered as an output stream and therefore materialized.
 * @param foreachFuncforeachRDD function
 * @param displayInnerRDDOpsWhether the detailed callsites and scopes of the RDDs generated
 *                           in the `foreachFuncto be displayed in the UI. If `false`, then
 *                           only the scopes and callsites of `foreachRDDwill override those
 *                           of the RDDs on the display.
 */
private defforeachRDD(
    foreachFunc: (RDD[T], Time) => Unit,
    displayInnerRDDOps: Boolean): Unit = {
  newForEachDStream(this,
    context.sparkContext.clean(foreachFunc, false), displayInnerRDDOps).register()
}

ForEachDStream對象中重寫了generateJob方法,調(diào)用父DStream的getOrCompute方法來生成RDD并封裝Job,傳入對該RDD的操作函數(shù)foreachFunc和time。dependencies方法定義為父DStream的集合。

/**
 * An internal DStream used to represent output operations like DStream.foreachRDD.
 * @param parent        Parent DStream
 * @param foreachFunc   Function to apply on each RDD generated by the parent DStream
 * @param displayInnerRDDOpsWhether the detailed callsites and scopes of the RDDs generated
 *                           by `foreachFuncwill be displayed in the UI; only the scope and
 *                           callsite of `DStream.foreachRDDwill be displayed.
 */
private[streaming]
classForEachDStream[T: ClassTag] (
    parent: DStream[T],
    foreachFunc: (RDD[T], Time) => Unit,
    displayInnerRDDOps: Boolean
  ) extendsDStream[Unit](parent.ssc) {

  override defdependencies: List[DStream[_]] = List(parent)

  override defslideDuration: Duration = parent.slideDuration

  override defcompute(validTime: Time): Option[RDD[Unit]] = None

  override defgenerateJob(time: Time): Option[Job] = {
    parent.getOrCompute(time) match{
      caseSome(rdd) =>
        valjobFunc = () => createRDDWithLocalProperties(time, displayInnerRDDOps) {
          foreachFunc(rdd, time)
        }
        Some(newJob(time, jobFunc))
      caseNone => None
    }
  }
}

DStreamGraph的generateJobs方法中會調(diào)用outputStream的generateJob方法,就是調(diào)用ForEachDStream的generateJob方法。

defgenerateJobs(time: Time): Seq[Job] = {
  logDebug("Generating jobs for time "+ time)
  valjobs = this.synchronized {
    outputStreams.flatMap { outputStream =>
      valjobOption = outputStream.generateJob(time)
      jobOption.foreach(_.setCallSite(outputStream.creationSite))
      jobOption
    }
  }
  logDebug("Generated "+ jobs.length + " jobs for time "+ time)
  jobs
}

DStream的generateJob定義如下,其子類中只有ForEachDStream重寫了generateJob方法。

/**
 * Generate a SparkStreaming job for the given time. This is an internal method that
 * should not be called directly. This default implementation creates a job
 * that materializes the corresponding RDD. Subclasses of DStream may override this
 * to generate their own jobs.
 */
private[streaming] defgenerateJob(time: Time): Option[Job] = {
  getOrCompute(time) match{
    caseSome(rdd) => {
      valjobFunc = () => {
        valemptyFunc = { (iterator: Iterator[T]) => {} }
        context.sparkContext.runJob(rdd, emptyFunc)
      }
      Some(newJob(time, jobFunc))
    }
    caseNone => None
  }
}

DStream的print方法內(nèi)部還是調(diào)用foreachRDD來實(shí)現(xiàn),傳入了內(nèi)部方法foreachFunc,來取出num+1個數(shù)后打印輸出。

/**
 * Print the first num elements of each RDD generated in this DStream. This is an output
 * operator, so this DStream will be registered as an output stream and there materialized.
 */
defprint(num: Int): Unit = ssc.withScope {
  defforeachFunc: (RDD[T], Time) => Unit = {
    (rdd: RDD[T], time: Time) => {
      val firstNum = rdd.take(num + 1)
      // scalastyle:off println
      println("-------------------------------------------")
      println("Time: "+ time)
      println("-------------------------------------------")
      firstNum.take(num).foreach(println)
      if(firstNum.length > num) println("...")
      println()
      // scalastyle:on println
    }
  }
  foreachRDD(context.sparkContext.clean(foreachFunc), displayInnerRDDOps = false)
}

總結(jié):JobScheduler是SparkStreaming 所有Job調(diào)度的中心,內(nèi)部有兩個重要的成員:

JobGenerator負(fù)責(zé)Job的生成,ReceiverTracker負(fù)責(zé)記錄輸入的數(shù)據(jù)源信息。

JobScheduler的啟動會導(dǎo)致ReceiverTracker和JobGenerator的啟動。ReceiverTracker的啟動導(dǎo)致運(yùn)行在Executor端的Receiver啟動并且接收數(shù)據(jù),ReceiverTracker會記錄Receiver接收到的數(shù)據(jù)meta信息。JobGenerator的啟動導(dǎo)致每隔BatchDuration,就調(diào)用DStreamGraph生成RDD Graph,并生成Job。JobScheduler中的線程池來提交封裝的JobSet對象(時(shí)間值,Job,數(shù)據(jù)源的meta)。Job中封裝了業(yè)務(wù)邏輯,導(dǎo)致最后一個RDD的action被觸發(fā),被DAGScheduler真正調(diào)度在Spark集群上執(zhí)行該Job。

上述內(nèi)容就是如何進(jìn)行JobScheduler內(nèi)幕實(shí)現(xiàn)和深度思考,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

分享標(biāo)題:如何進(jìn)行JobScheduler內(nèi)幕實(shí)現(xiàn)和深度思考
本文來源:http://aaarwkj.com/article26/ispgjg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供面包屑導(dǎo)航、網(wǎng)站設(shè)計(jì)、標(biāo)簽優(yōu)化、自適應(yīng)網(wǎng)站、網(wǎng)站收錄、App設(shè)計(jì)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

微信小程序開發(fā)
精品视频偷拍一区二区三区| 日韩精品a区二区在线电影| 亚洲精品在线观看第一页| 日韩av熟女人妻一区二| 精品色欧美色国产一区国产| 老司机精品成人免费视频| 国产美女冒白浆免费网站| 丰满人妻在线一区二区三区| 99久久这里只有精品视频| 婷婷激情亚洲综合综合久久| 日本少妇入口一区二区| 日韩精品a区二区在线电影| 亚洲精品丝袜成人偷拍| 日本中文字幕免费一区| 久久九九精品日本人妻视频| 亚洲女人天堂av在线| 亚洲欧美日韩在线观看a三区| 国产91日韩欧美在线观看 | 欧美日韩国产特级性生活| 日本一区二区三区播放| 欧美亚洲成人免费电影| 久热在线这里只有精品| 日本高清免费观看一区| 少妇内射呻吟中文字幕视频| 一级片一区二区中文字幕| 国产精品麻豆色哟哟av| 国产美女精品一区二区三区| 色六月婷婷六月久久六月| 亚洲国产成人91精品| 国产综合永久精品日韩鬼片| 国产中文字幕一区久久| 亚洲精品成人久久国产| 日韩精品成人亚洲天堂| 99热这里在线只有精品| 亚洲乱色熟女一区二区三区麻豆| 日韩精品亚洲专区在线观看 | 日韩成年人高清精品不卡一区二区 | 女同蝴蝶在线看完整版| 国产麻豆精品传媒av| 国产成人亚洲精品在线看| 午夜最新福利在线视频|