SparkContext 內 YARN 的啟動流程
https://github.com/apache/spark/blob/master/core/src/main/scala/org/apache/spark/SparkContext.scala
case "yarn-standalone" | "yarn-cluster" =>
if (master == "yarn-standalone") {
logWarning(
"\"yarn-standalone\" is deprecated as of Spark 1.0. Use \"yarn-cluster\" instead.")
}
val scheduler = try {
val clazz = Class.forName("org.apache.spark.scheduler.cluster.YarnClusterScheduler")
val cons = clazz.getConstructor(classOf[SparkContext])
cons.newInstance(sc).asInstanceOf[TaskSchedulerImpl]
} catch {
// TODO: Enumerate the exact reasons why it can fail
// But irrespective of it, it means we cannot proceed !
case e: Exception => {
throw new SparkException("YARN mode not available ?", e)
}
}
val backend = try {
val clazz =
Class.forName("org.apache.spark.scheduler.cluster.YarnClusterSchedulerBackend")
val cons = clazz.getConstructor(classOf[TaskSchedulerImpl], classOf[SparkContext])
cons.newInstance(scheduler, sc).asInstanceOf[CoarseGrainedSchedulerBackend]
} catch {
case e: Exception => {
throw new SparkException("YARN mode not available ?", e)
}
}
scheduler.initialize(backend)
(backend, scheduler)
case "yarn-client" =>
val scheduler = try {
val clazz =
Class.forName("org.apache.spark.scheduler.cluster.YarnClientClusterScheduler")
val cons = clazz.getConstructor(classOf[SparkContext])
cons.newInstance(sc).asInstanceOf[TaskSchedulerImpl]
} catch {
case e: Exception => {
throw new SparkException("YARN mode not available ?", e)
}
}
val backend = try {
val clazz =
Class.forName("org.apache.spark.scheduler.cluster.YarnClientSchedulerBackend")
val cons = clazz.getConstructor(classOf[TaskSchedulerImpl], classOf[SparkContext])
cons.newInstance(scheduler, sc).asInstanceOf[CoarseGrainedSchedulerBackend]
} catch {
case e: Exception => {
throw new SparkException("YARN mode not available ?", e)
}
}
YarnClusterScheduler
YarnClusterSchedulerBackend
YarnClientClusterScheduler
YarnClientSchedulerBackend
source code 位於
https://github.com/apache/spark/tree/master/yarn/src/main/scala/org/apache/spark/scheduler/cluster
2014年6月1日 星期日
Battle Isle 1 (1991,DOS) PART 11-15 Walkthrough 狂島浴血 11-15 關 (過關實錄)
狂島浴血 第十一關-第十五關 過關實錄
Part 11. VALEY 第十一關 總時間(time) 26:58
Part 12. TESTY 第十二關 總時間(time) 47:25
Part 13. TERRA 第十三關 總時間(time) 57:05
Part 14. SLAVE 第十四關 總時間(time) 1:02:47
Part 15. NEVER 第十五關 總時間(time) 42:28
Part 11. VALEY 第十一關 總時間(time) 26:58
Part 12. TESTY 第十二關 總時間(time) 47:25
Part 13. TERRA 第十三關 總時間(time) 57:05
Part 14. SLAVE 第十四關 總時間(time) 1:02:47
Part 15. NEVER 第十五關 總時間(time) 42:28
Battle Isle 1 (1991,DOS) PART 6-10 Walkthrough 狂島浴血 6-10 關 (過關實錄)
狂島浴血 第六關-第十關 過關實錄
Part 6. RUSTY 第六關 總時間(time) 24:22
Part 7. FIFTH 第七關 總時間(time) 35:29
Part 8. VESUV 第八關 總時間(time) 32:29
Part 9. MAGIC 第九關 總時間(time) 44:11
Part 10. SPACE 第十關 總時間(time) 39:12
Part 6. RUSTY 第六關 總時間(time) 24:22
Part 7. FIFTH 第七關 總時間(time) 35:29
Part 8. VESUV 第八關 總時間(time) 32:29
Part 9. MAGIC 第九關 總時間(time) 44:11
Part 10. SPACE 第十關 總時間(time) 39:12
Battle Isle 1 (1991,DOS) PART 1-5 Walkthrough 狂島浴血 1-5 關 (過關實錄)
狂島浴血過關紀錄實況
Battle Isle 1 - 1991
Part 1. CONRA 第一關 總時間(time) 5:41
Part 2. PHASE 第二關 總時間(time) 7:44
Part 3. EXOTY 第三關 總時間(time) 9:02
Part 4. MOUNT 第四關 總時間(time) 18:54
Part 5. FIGHT 第五關 總時間(time) 20:46
Battle Isle 1 - 1991
Part 1. CONRA 第一關 總時間(time) 5:41
訂閱:
文章 (Atom)