transformation and action of spark
来源:互联网 发布:淘宝网小花仙日本食玩 编辑:程序博客网 时间:2024/04/27 23:42
转换(transformation)
下面的列表列出了一些通用的转换。 请参考 RDD API doc (Scala, Java, Python) 和 pair RDD functions doc (Scala, Java) 了解细节.
转换含义map(func)返回一个新分布式数据集,由每一个输入元素经过func函数转换后组成filter(func)返回一个新数据集,由经过func函数计算后返回值为true的输入元素组成flatMap(func)类似于map,但是每一个输入元素可以被映射为0或多个输出元素(因此func应该返回一个序列,而不是单一元素)mapPartitions(func)类似于map,但独立地在RDD的每一个分块上运行,因此在类型为T的RDD上运行时,func的函数类型必须是Iterator[T] => Iterator[U]mapPartitionsWithSplit(func)类似于mapPartitions, 但func带有一个整数参数表示分块的索引值。因此在类型为T的RDD上运行时,func的函数类型必须是(Int, Iterator[T]) => Iterator[U]sample(withReplacement,fraction, seed)根据fraction指定的比例,对数据进行采样,可以选择是否用随机数进行替换,seed用于指定随机数生成器种子union(otherDataset)返回一个新的数据集,新数据集是由源数据集和参数数据集联合而成distinct([numTasks]))返回一个包含源数据集中所有不重复元素的新数据集groupByKey([numTasks])在一个(K,V)对的数据集上调用,返回一个(K,Seq[V])对的数据集注意:默认情况下,只有8个并行任务来做操作,但是你可以传入一个可选的numTasks参数来改变它reduceByKey(func, [numTasks])在一个(K,V)对的数据集上调用时,返回一个(K,V)对的数据集,使用指定的reduce函数,将相同key的值聚合到一起。类似groupByKey,reduce任务个数是可以通过第二个可选参数来配置的aggregateByKey(zeroValue)(seqOp,combOp, [numTasks])根据提供的函数进行聚合。When called on a dataset of (K, V) pairs, returns a dataset of (K, U) pairs where the values for each key are aggregated using the given combine functions and a neutral "zero" value. Allows an aggregated value type that is different than the input value type, while avoiding unnecessary allocations. Like in
groupByKey
, the number of reduce tasks is configurable through an optional second argument.sortByKey([ascending], [numTasks])在一个(K,V)对的数据集上调用,K必须实现Ordered接口,返回一个按照Key进行排序的(K,V)对数据集。升序或降序由ascending布尔参数决定join(otherDataset, [numTasks])在类型为(K,V)和(K,W)类型的数据集上调用时,返回一个相同key对应的所有元素对在一起的(K, (V, W))数据集cogroup(otherDataset, [numTasks])在类型为(K,V)和(K,W)的数据集上调用,返回一个 (K, Seq[V], Seq[W])元组的数据集。这个操作也可以称之为groupwithcartesian(otherDataset)笛卡尔积,在类型为 T 和 U 类型的数据集上调用时,返回一个 (T, U)对数据集(两两的元素对)pipe(command,[envVars])Pipe each partition of the RDD through a shell command, e.g. a Perl or bash script. RDD elements are written to the process's stdin and lines output to its stdout are returned as an RDD of strings.coalesce(numPartitions)Decrease the number of partitions in the RDD to numPartitions. Useful for running operations more efficiently after filtering down a large dataset.repartition(numPartitions)Reshuffle the data in the RDD randomly to create either more or fewer partitions and balance it across them. This always shuffles all data over the network.动作(actions)
下面的列表列出了一些通用的action操作. 请参考 RDD API doc (Scala, Java, Python) 和 pair RDD functions doc (Scala,Java) 了解细节.
动作含义reduce(func)通过函数func(接受两个参数,返回一个参数)聚集数据集中的所有元素。这个功能必须可交换且可关联的,从而可以正确的被并行执行。collect()在驱动程序中,以数组的形式,返回数据集的所有元素。这通常会在使用filter或者其它操作并返回一个足够小的数据子集后再使用会比较有用。count()返回数据集的元素的个数。first()返回数据集的第一个元素(类似于take(1))take(n)返回一个由数据集的前n个元素组成的数组。注意,这个操作目前并非并行执行,而是由驱动程序计算所有的元素takeSample(withReplacement,num, seed)返回一个数组,在数据集中随机采样num个元素组成,可以选择是否用随机数替换不足的部分,Seed用于指定的随机数生成器种子takeOrdered(n,[ordering])Return the firstn elements of the RDD using either their natural order or a custom comparator.saveAsTextFile(path)将数据集的元素,以textfile的形式,保存到本地文件系统,HDFS或者任何其它hadoop支持的文件系统。对于每个元素,Spark将会调用toString方法,将它转换为文件中的文本行saveAsSequenceFile(path)将数据集的元素,以Hadoop sequencefile的格式,保存到指定的目录下,本地系统,HDFS或者任何其它hadoop支持的文件系统。这个只限于由key-value对组成,并实现了Hadoop的Writable接口,或者隐式的可以转换为Writable的RDD。(Spark包括了基本类型的转换,例如Int,Double,String,等等)saveAsObjectFile(path)(Java and Scala)Write the elements of the dataset in a simple format using Java serialization, which can then be loaded using
SparkContext.objectFile()
.countByKey()对(K,V)类型的RDD有效,返回一个(K,Int)对的Map,表示每一个key对应的元素个数foreach(func)在数据集的每一个元素上,运行函数func进行更新。这通常用于边缘效果,例如更新一个累加器,或者和外部存储系统进行交互,例如HBase 0 0
- transformation and action of spark
- Spark学习笔记 --- Transformation and Action
- Spark:Transformation和Action
- Spark: Transformation和Action
- Spark: Transformation和Action
- Spark Transformation和Action
- spark中的action和transformation
- spark中的action和transformation
- spark中的action和transformation
- spark中的action和transformation
- spark transformation和action算子
- Spark的action和transformation
- spark的transformation与action
- 【spark】Spark transformation和action的算子
- spark中RDD的transformation&action
- spark RDD transformation和action操作
- spark常用函数:transformation和action
- spark中RDD的transformation&action
- 创建文件夹
- poj2296 Map Labeler(2-sat+二分)
- ajax 中
- 389. Find the Difference
- 小猫统计:基于查询结果定制图表
- transformation and action of spark
- #公开课#嵌入式系统的软硬件协同设计
- leetcode:数学:Bulb Switcher(319)
- spring-boot-started-logging logback常用配置之<filter>标签详解
- LeetCode : 223. Rectangle Area
- 【例题】【搜索(迭代加深)】NKOJ 1628 岳麓山提水
- Android 关于从后台获得时间的字符串转为日期格式再变成字符串
- 华为内部实施微服务架构
- javaweb项目开发,思想和细节一样重要