Learning Spark 第四章——键值对处理
本章主要介绍Spark如何处理键值对。K-V RDDs通常用于聚集操作,使用相同的key聚集或者对不同的RDD进行聚集。部分情况下,需要将spark中的数据记录转换为键值对然后进行聚集处理。
我们也会对键值对RDD的高级特性——分区进行讨论,用户可以控制RDD在节点间的布局,确保数据在同一机器上面,减少通信开销,将极大地提高效率。数据分区的选择与单机程序数据结构的选择一样,都能对程序的性能产生极大的影响。
主要分为以下几个章节:
- 创建PairRDD
- Transformation on Pair RDD
- Actions on Pair RDD
- 数据分区partition
Motivation
spark对Pair RDD提供了一系列的特殊操作。例如reduceByKey可以对RDD按照key进行聚合;join方法可以对两个RDD按照相同元素进行分组合并。
创建 Pair RDD
有多重方法可以创建Pair RDD,也可以将其他类型的RDD转化为Pair RDD。 下面代码将字符串第一个单词作为key
scala示例:
input.map(x => (x.split(" ")(0), x))
java没有内置的元组类型,可以引入scala.Tuple2,代码如下
PairFunction<String, String, String> keyData = new PairFunction<String, String, String>() { public Tuple2<String, String> call(String x) { returnnew Tuple2(x.split(" ")[0], x);
}
};
JavaPairRDD<String, String> rdd = input.mapToPair(keyData);
Transformation on Pair RDDs
Pair RDD可以进行通用的转换操作,例如map等。由于它包含元组,我们传入的函数其参数应该为元组。
reduceByKey:与reduce类似,对RDD进行合并。对RDD中每个元素进行操作,按照相同的key,对value进行操作并合并;
foldByKey:提供初值为0,要求合并操作对0没有影响。
以上两个转换在实际执行时,会先在各个节点进行combine,然后再进行全局合并,提升性能。
示例1:求取平均值
示例2:word count
实际上word count可以使用countByValue简化计算
input.flatMap(x =>x.split(" ")).countByValue()
combineByKey:是按照Key进行合并的通用函数,可以实现大部分按单Key合并的操作,它允许用户输入与输出类型不同;可以根据情况禁用map side aggregation(map过程的合并操作),例如groupByKey的map side aggregatation并不能提高性能,一般禁用。
示例:按key求平均值
combineByKey的数据流如下图所示:
并行级别调整
RDD的分区数直接影响着spark执行的并行程度,可以指定分区数对spark的并行程度进行微调。
代码示例
有 时需要在grouping和aggregating的上下文环境之外改变RDD分区,可以通过Spark提供的repartition工具,由于涉及 shuffle操作,代价很高。当减少RDD分区时,可以使用coalesce合并,数据移动更少,性能更优。可以通过 rdd.partitions.size()确定分区数,判断是否可用coalesce。
分组
groupBy将RDD元素按照函数处理,将结果作为主键进行分组;
groupByKey按照主键进行分组;
可以使用特定的reduce函数代替groupBy+reduce,因为可以将归约后结果放入RDD,而不是归约前的数据,提高效率。
cogroup可以对多个RDD按照相同主键进行分组,是join连接处理的基础。
连接
spark支持内连接、左外连接、右外连接和交叉链接。参照数据库中join的概念进行理解。
排序
RDD排序可以保证后续的调用,数据都是有序的。
例如将String与int混合的RDD进行排序:
Pair RDD可执行的转换总结如下所示:
Action on Pair RDDs
决定RDDs分区
PageRank 是个迭代算法,要执行很多的连接,所以这是个 RDD 分区的好用例。 该算法包括两个数据集:一个是(pageID, linkList),其元素包含了每个页的邻居 列表;另一个是(pageID, rank),其元素是每个页的当前 rank。处理流程如下:
1. 初始化每页的 rank 为 1.0
2. 对每次迭代,页面 p 发送 rank(p)/numNeighbors(p)的贡献给它的邻居(该 页连接出去的)
3. 设置每页的 rank 为 0.15+0.85*contributionsReceived。
最后两步重复的多次迭代,算法会收敛到每个页面都有正确的 PageRank 值。实 际上,一般要运行大约 10 次迭代。
- 将link持久化,避免分区间数据交互;
- 使用mapValues创建ranks,保留了分区信息,第一次join开销不大;
- 最后在reduceByKey后面使用mapValues,因为reduceByKey的结果时有分区的,此时mapValues继承分区信息,提高效率;
自定义分区
Learning Spark 第四章——键值对处理的更多相关文章
- 《Deep learning》第四章——数值计算
数值计算 机器学习算法通常需要大量的数值计算.这通常是指通过迭代过程更新解的估计值来解决数学问题的算法,而不是通过解析过程推导出公式来提供正确解的方法.常见的操作包括优化(找到最小化或最大化函数值的参 ...
- Learning Spark中文版--第四章--使用键值对(2)
Actions Available on Pair RDDs (键值对RDD可用的action) 和transformation(转换)一样,键值对RDD也可以使用基础RDD上的action(开工 ...
- Learning Spark中文版--第四章--使用键值对(1)
本章介绍了如何使用键值对RDD,Spark中很多操作都基于此数据类型.键值对RDD通常在聚合操作中使用,而且我们经常做一些初始的ETL(extract(提取),transform(转换)和load ...
- Spark学习之键值对操作总结
键值对 RDD 是 Spark 中许多操作所需要的常见数据类型.键值对 RDD 通常用来进行聚合计算.我们一般要先通过一些初始 ETL(抽取.转化.装载)操作来将数据转化为键值对形式.键值对 RDD ...
- Spark 键值对RDD操作
键值对的RDD操作与基本RDD操作一样,只是操作的元素由基本类型改为二元组. 概述 键值对RDD是Spark操作中最常用的RDD,它是很多程序的构成要素,因为他们提供了并行操作各个键或跨界点重新进行数 ...
- Spark中的键值对操作-scala
1.PairRDD介绍 Spark为包含键值对类型的RDD提供了一些专有的操作.这些RDD被称为PairRDD.PairRDD提供了并行操作各个键或跨节点重新进行数据分组的操作接口.例如,Pa ...
- Spark中的键值对操作
1.PairRDD介绍 Spark为包含键值对类型的RDD提供了一些专有的操作.这些RDD被称为PairRDD.PairRDD提供了并行操作各个键或跨节点重新进行数据分组的操作接口.例如,Pa ...
- 3. 键值对RDD
键值对RDD是Spark中许多操作所需要的常见数据类型.除了在基础RDD类中定义的操作之外,Spark为包含键值对类型的RDD提供了一些专有的操作在PairRDDFunctions专门进行了定义.这些 ...
- 【原】Learning Spark (Python版) 学习笔记(二)----键值对、数据读取与保存、共享特性
本来应该上周更新的,结果碰上五一,懒癌发作,就推迟了 = =.以后还是要按时完成任务.废话不多说,第四章-第六章主要讲了三个内容:键值对.数据读取与保存与Spark的两个共享特性(累加器和广播变量). ...
随机推荐
- SpringMVC(四) RequestMapping请求方式
常见的Rest API的Get和POST的测试参考代码如下,其中web.xml和Springmvc的配置文件参考HelloWorld测试代码中的配置. 控制类的代码如下: package com.ti ...
- HFSS仿真小例
微带拐角对比实验 微带四分之波长变换器插入前后对比 P1 P2 分配波端口激励,设置差分信号线 微带线差分对的差模阻抗随着差分线间距的增大而增大,随着线宽的增大而减小: 共模阻抗随着差分线间距的增大而 ...
- .NET跨平台之旅:升级ASP.NET Core示例站点
ASP.NET Core示例站点网址:http://about.cnblogs.com/ 首先安装最新版的 .NET Core 运行环境,从 https://github.com/dotnet/cli ...
- Android---观察者模式的简单实现demo
ObserverListerner: subjectListener: 观察者管理类: 使用方法: 1. 接口: 2. 注册观察者: 3. 通知:(触发事件执行): 4. 实现方法:(都要写, 只在要 ...
- 内核控制Meta标签:让360浏览器默认使用极速模式打开网页(转)
为了让网站页面不那么臃肿,也懒的理IE了,同时兼顾更多的国内双核浏览器,在网页页头中添加了下面两行Meta控制标签. 1,网页头部加入 <meta name="renderer&quo ...
- vue.js第六课
class与style绑定 绑定HTML class 对象语法 数组语法 绑定内联样式 对象语法 数组语法 自动添加前缀 1.class与style绑定. 数据绑定一个常见需求就是 操作元素的clas ...
- poj2217
Secretary Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 1257 Accepted: 515 Descript ...
- C#-WebForm-Session、Cookie-登录验证(未登录跳至登录界面)、隐藏地址栏传值
Post 传值(看不见的传值) Get 传值(看得见的传值) Session - 全局变量组 存放位置:服务端 作用:只要里面有内容,那么这个网站中所有的C#端都能访问到这个变量 -- object类 ...
- IRandomAccessStream, IBuffer, Stream, byte[] 之间相互转换
/* * 用于实现 IRandomAccessStream, IBuffer, Stream, byte[] 之间相互转换的帮助类 */ using System;using System.IO;us ...
- 关于delphi7的四舍五入
round 函数是银行用的 采用了 四舍六入5留偶 网上找到了个实现方法 先乘1000,用Trunc取整,除10取余,余数再取整,如果大于5,进位,小于5不进位. 函数就好写了 现在只写一个保留两 ...