Apache Spark Tutorials
Apache Spark Tutorials
Apache Spark Tutorials
NNK
November 30, 2019
Apache Spark RDD
RDD Transformations are Spark operations when executed on RDD, it results in a
single or multiple new RDD’s. Since RDD are immutable in nature, transformations
always create new RDD without updating an existing one hence, this creates
an RDD lineage.
RDD Lineage is also known as the RDD operator graph or RDD dependency graph.
In this tutorial, you will learn lazy transformations, types of transformations, a
complete list of transformation functions using wordcount example in scala.
Narrow Transformation
Narrow transformations are the result of map() and filter() functions and these
compute data that live on a single partition meaning there will not be any data
movement between partitions to execute narrow transformations.
Functions such
as map(), mapPartition(), flatMap(), filter(), union() are some
examples of narrow transformation
Wider Transformation
Search:
TRANSFORMATION
METHOD USAGE AND DESCRIPTION
METHODS
cache() Caches the RDD
filter() Returns a new RDD after applying filter function on source dataset.
TRANSFORMATION
METHOD USAGE AND DESCRIPTION
METHODS
flatMap() Returns flattern map meaning if you have a dataset with array, it converts each
return 0 or more items in output for each element in dataset.
map() Applies transformation function on dataset and returns same number of elemen
mapPartitions() Similar to map, but executs transformation function on each partition, This give
mapPartitionsWithIndex() Similar to map Partitions, but also provides func with an integer value represen
randomSplit() Splits the RDD by the weights specified in the argument. For example rdd.rando
union() Comines elements from source dataset and the argument and returns combined
Math set operations.
sample() Returns the sample dataset.
intersection() Returns the dataset which contains elements in both source dataset and an arg
distinct() Returns the dataset by eliminating all duplicated elements.
repartition() Return a dataset with number of partition specified in the argument. This opera
return lesser or more partioned RDD based on the input supplied.
coalesce() Similar to repartition by operates better when we want to the decrease the part
data from fewer nodes compared with all nodes by repartition.
Spark RDD Transformations with Examples
In this section, I will explain a few RDD Transformations with word count example
in scala, before we start first, let’s create an RDD by reading a text file. The text
file used here is available at the GitHub and, the scala example is available
at GitHub project for reference.
val spark:SparkSession = SparkSession.builder()
.master("local[3]")
.appName("SparkByExamples.com")
.getOrCreate()
val sc = spark.sparkContext
flatMap() transformation flattens the RDD after applying the function and
returns a new RDD. On the below example, first, it splits each record by space in an
RDD and finally flattens it. Resulting RDD consists of a single word on each
record.
val rdd2 = rdd.flatMap(f=>f.split(" "))
Copy
map() Transformation
map() transformation is used the apply any complex operations like adding a
column, updating a column e.t.c, the output of map transformations would always
have the same number of records as input.
In our word count example, we are adding a new column with value 1 for each
word, the result of the RDD is PairRDDFunctions which contains key -value pairs,
word of type String as Key and 1 of type Int as value. For your understanding, I’ve
defined rdd3 variable with type.
reduceByKey() merges the values for each key with the function specified. In
our example, it reduces the word string by applying the sum function on value. The
result of our RDD contains unique words and their count.
val rdd5 = rdd3.reduceByKey(_ + _)
Copy
sortByKey() Transformation
package com.sparkbyexamples.spark.rdd
import org.apache.spark.rdd.RDD
import org.apache.spark.sql.SparkSession
object WordCountExample {
def main(args:Array[String]): Unit = {
val sc = spark.sparkContext
//rdd.coalesce(3)
rdd.collect().foreach(println)
//Filter transformation
val rdd4 = rdd3.filter(a=> a._1.startsWith("a"))
rdd4.foreach(println)
//ReduceBy transformation
val rdd5 = rdd3.reduceByKey(_ + _)
rdd5.foreach(println)
//Action - foreach
rdd6.foreach(println)
//Action - count
println("Count : "+rdd6.count())
//Action - first
val firstRec = rdd6.first()
println("First Record : "+firstRec._1 + ","+ firstRec._2)
//Action - max
val datMax = rdd6.max()
println("Max Record : "+datMax._1 + ","+ datMax._2)
//Action - reduce
val totalWordCount = rdd6.reduce((a,b) => (a._1+b._1,a._2))
println("dataReduce Record : "+totalWordCount._1)
//Action - take
val data3 = rdd6.take(3)
data3.foreach(f=>{
println("data3 Key:"+ f._1 +", Value:"+f._2)
})
//Action - collect
val data = rdd6.collect()
data.foreach(f=>{
println("Key:"+ f._1 +", Value:"+f._2)
})
//Action - saveAsTextFile
rdd5.saveAsTextFile("c:/tmp/wordCount")
}
}
Copy
Conclusion