GithubHelp home page GithubHelp logo

airwindow / spark Goto Github PK

View Code? Open in Web Editor NEW

This project forked from apache/spark

0.0 0.0 0.0 302.79 MB

Apache Spark

License: Apache License 2.0

Scala 72.41% Java 9.67% Shell 0.48% JavaScript 0.48% Python 7.10% Makefile 0.02% R 2.83% C 0.01% CSS 0.06% Batchfile 0.07% Thrift 0.16% HTML 0.17% ANTLR 0.11% PLpgSQL 0.61% PowerShell 0.01% Roff 0.04% HiveQL 4.35% q 0.35% Dockerfile 0.02% TSQL 1.05%

spark's Introduction

Dive into Original Spark Source Code.

Original source code to look into https://github.com/apache/spark/tree/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark

Some useful notes.

https://github.com/JerryLead/SparkInternals

Introduction to AmpLab Spark Internals - Matei Zaharia (Databricks)

https://www.youtube.com/watch?v=49Hr5xZyTEA

A Deeper Understanding of Spark Internals - Aaron Davidson (Databricks)

https://www.youtube.com/watch?v=dmL0N3qfSc8

Interesting code & docs to look into

The collaboration between Job and Mesos https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/Executor.scala https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/SimpleJob.scala https://hadoop.apache.org/docs/stable/hadoop-mapreduce-client/hadoop-mapreduce-client-app/apidocs/org/apache/hadoop/mapreduce/v2/app/webapp/dao/TasksInfo.html http://mesos.apache.org/api/latest/java/org/apache/mesos/Executor.html http://mesos.apache.org/api/latest/java/org/apache/mesos/Protos.TaskStatus.html

Schedulers

https://github.com/rohgar/scala-spark-4/wiki/Wide-vs-Narrow-Dependencies https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/Scheduler.scala https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/DAGScheduler.scala https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/LocalScheduler.scala#L33

MesoScheduler

http://mesos.apache.org/documentation/latest/architecture/ http://mesos.apache.org/api/latest/java/org/apache/mesos/MesosSchedulerDriver.html http://mesos.apache.org/api/latest/java/org/apache/mesos/Scheduler.html https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/MesosScheduler.scala#L203

Fetcher(Pull Model) https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/ShuffleManager.scala#L71 https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/ShuffleMapTask.scala#L29 https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/MapOutputTracker.scala#L46 https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/MapOutputTracker.scala#L22 https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/ShuffleFetcher.scala https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/SimpleShuffleFetcher.scala#L16

ShuffleDependency https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/SparkContext.scala#L316 https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/PairRDDFunctions.scala#L58 https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/ShuffledRDD.scala#L39 https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/ShuffleMapTask.scala#L40 https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/MapOutputTracker.scala#L14 https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/Dependency.scala

ShuffleRDD LifeCycle https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/PairRDDFunctions.scala#L63 https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/Dependency.scala#L10 https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/ShuffledRDD.scala#L25 https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/DAGScheduler.scala#L153 note: only ShuffleDep causes the add of new stage https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/DAGScheduler.scala#L130

Transformations & RDD https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/RDD.scala#L89 https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/RDD.scala#L290 https://www.scala-lang.org/api/current/scala/collection/Iterator.html https://github.com/apache/spark/blob/5b021ce0990ec675afc6939cc2c06f041c973d17/core/src/main/scala/spark/RDD.scala#L74

spark's People

Contributors

mateiz avatar rxin avatar pwendell avatar cloud-fan avatar tdas avatar hyukjinkwon avatar srowen avatar joshrosen avatar zsxwing avatar dongjoon-hyun avatar viirya avatar gatorsmile avatar liancheng avatar mengxr avatar yanboliang avatar marmbrus avatar ankurdave avatar yhuai avatar wangyum avatar shivaram avatar scrapcodes avatar jegonzal avatar jerryshao avatar ueshin avatar jkbradley avatar felixcheung avatar aarondav avatar maropu avatar maxgekk avatar gengliangwang avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.