Spark

一.coalesce

  1.简介

    coalesce常用来合并分区,第二个参数是合并分区时是否产生shuffle。true为产生shuffle,false为不产生shuffle。默认是false不产生shuffle。如果coalesce设置的分区数比原来的分区数还大的话若设置为false则不起作用。如果设置为true则效果等价于repartition。即repartition(numPartitions) = coalesce(numPartitions)。

  2.测试数据

    val array = Array("spark,scala,6", "hadoop,java,12", "tensorflow,python,8", "solr,java,16", "hbase,java,11")

  3.代码           

    /**
    * coalesce算子,常用于减少分区
     */
    val befParNum = rdd.getNumPartitions
    rdd = rdd.coalesce(1, false) // true为产生shuffle
    val coalParNum = rdd.getNumPartitions
    /**
     * repartition与之类型,一般增大分区数
     */
    rdd = rdd.repartition(3)
    val reParNum = rdd.getNumPartitions
    println("初始分区数:" + befParNum + ",coalesce分区后:" + coalParNum + ",repartition分区后:" + reParNum)

  4.结果

    初始分区数:2,coalesce分区后:1,repartition分区后:3

二.zip,zipWithIndex

  1.简介

    zip将两个RDD中的元素变成一个KV格式的RDD,两个RDD的每个分区元素个数必须相同。zipWithIndex该函数将RDD中的元素和这个元素在RDD中的索引下标【从0开始】组合成【K,V】键值对。

  2.测试数据

   val zip_array_left = Array(1,2,5,6,7,5,3,1)
   val zip_array_left_2 = Array(1,2,5,6,7,8,9,0)
   val zip_array_right = Array("spark", "scala", "hive", "hbase", "python", "hive", "hbase", "hbase")

  3.代码

   /**
   * zip
    */
   //to rdd
   val zip_left = sc.parallelize(zip_array_left)
   val zip_left_2 = sc.parallelize(zip_array_left_2)
   val zip_right = sc.parallelize(zip_array_right)    //zip
   val zip = zip_left.zip(zip_right)
   zip.foreach(println)
   println("------------------")    val zip_2 = zip_left_2.zip(zip_right)
   /**
    * zipWithIndex
  */
   val zip_index = zip.zipWithIndex()
   zip_index.foreach(println)

  4.结果

    (1,spark)
    (2,scala)
    (5,hive)
    (6,hbase)
    (7,python)
    (5,hive)
    (3,hbase)
    (1,hbase)
    ------------------
    ((1,spark),0)
    ((7,python),4)
    ((2,scala),1)
    ((5,hive),2)
    ((5,hive),5)
    ((6,hbase),3)
    ((3,hbase),6)
    ((1,hbase),7)

三.countByKey,countByValue

  1.简介

    countByKey作用在K,V格式的RDD之上,统计相同key的个数。countByValue作用在K,V格式的RDD之上,统计相同value的个数。

  2.测试数据

    同上

  3.代码

   /**
   * countByKey
   */
   val zip_key = zip.countByKey()
   zip_key.foreach(println)
   println("------------------")
   /**
   * countByValue
   */
   val zip_value = zip.countByValue()
   zip_value.foreach(println)

  4.结果 

    (5,2)
    (1,2)
    (6,1)
    (2,1)
    (7,1)
    (3,1)
    ------------------
    ((7,python),1)
    ((1,spark),1)
    ((2,scala),1)
    ((1,hbase),1)
    ((3,hbase),1)
    ((6,hbase),1)
    ((5,hive),2)

四.cogroup

  1.简介

    cogroup 对两个内部数据结构为元组(仅有两个元素的元组)的数据进行匹配,把匹配上的value值保存到一个元组中。

  2.测试数据

    同上

  3.代码  

   zip.cogroup(zip_2).foreach(println)

  4.结果

    (0,(CompactBuffer(),CompactBuffer(hbase)))
    (1,(CompactBuffer(spark, hbase),CompactBuffer(spark)))
    (7,(CompactBuffer(python),CompactBuffer(python)))
    (3,(CompactBuffer(hbase),CompactBuffer()))
    (6,(CompactBuffer(hbase),CompactBuffer(hbase)))
    (9,(CompactBuffer(),CompactBuffer(hbase)))
    (8,(CompactBuffer(),CompactBuffer(hive)))
    (5,(CompactBuffer(hive, hive),CompactBuffer(hive)))
    (2,(CompactBuffer(scala),CompactBuffer(scala))) 

五.flatten

  1.简介

    把多层集合数据展开成一个集合。

  2.测试数据

   val sourceDate = Array("zhen@zhen01/2018-09-04_18;57;02_SOURCE",
   "zhen@zhen02/2018-09-05_11;37;11_SOURCE","zhen@zhen03/2018-09-06_11;37;11_TEST")
   val resultDate = Array("zhen@zhen01/2018-09-04_18;57","zhen@zhen02/2018-09-05_11;37",
    "zhen@zhen03/2018-09-06_11;37")

  3.代码

   val seq = Seq(sourceDate, resultDate)
   seq.flatten.foreach(println)

  4.结果

    zhen@zhen01/2018-09-04_18;57;02_SOURCE
    zhen@zhen02/2018-09-05_11;37;11_SOURCE
    zhen@zhen03/2018-09-06_11;37;11_TEST
    zhen@zhen01/2018-09-04_18;57
    zhen@zhen02/2018-09-05_11;37
    zhen@zhen03/2018-09-06_11;37

Spark算子代码实践的更多相关文章

  1. UserView--第二种方式(避免第一种方式Set饱和),基于Spark算子的java代码实现

      UserView--第二种方式(避免第一种方式Set饱和),基于Spark算子的java代码实现   测试数据 java代码 package com.hzf.spark.study; import ...

  2. UserView--第一种方式set去重,基于Spark算子的java代码实现

    UserView--第一种方式set去重,基于Spark算子的java代码实现 测试数据 java代码 package com.hzf.spark.study; import java.util.Ha ...

  3. Spark—RDD编程常用转换算子代码实例

    Spark-RDD编程常用转换算子代码实例 Spark rdd 常用 Transformation 实例: 1.def map[U: ClassTag](f: T => U): RDD[U]  ...

  4. 【Spark算子】:reduceByKey、groupByKey和combineByKey

    在spark中,reduceByKey.groupByKey和combineByKey这三种算子用的较多,结合使用过程中的体会简单总结: 我的代码实践:https://github.com/wwcom ...

  5. 我的Spark SQL单元测试实践

    最近加入一个Spark项目,作为临时的开发人员协助进行开发工作.该项目中不存在测试的概念,开发人员按需求进行编码工作后,直接向生产系统部署,再由需求的提出者在生产系统检验程序运行结果的正确性.在这种原 ...

  6. Spark算子---实战应用

    Spark算子实战应用 数据集 :http://grouplens.org/datasets/movielens/ MovieLens 1M Datase 相关数据文件 : users.dat --- ...

  7. ReactiveCocoa代码实践之-更多思考

    三.ReactiveCocoa代码实践之-更多思考 1. RACObserve()宏形参写法的区别 之前写代码考虑过 RACObserve(self.timeLabel , text) 和 RACOb ...

  8. ReactiveCocoa代码实践之-RAC网络请求重构

    前言 RAC相比以往的开发模式主要有以下优点:提供了统一的消息传递机制:提供了多种奇妙且高效的信号操作方法:配合MVVM设计模式和RAC宏绑定减少多端依赖. RAC的理论知识非常深厚,包含有FRP,高 ...

  9. (转)Spark 算子系列文章

    http://lxw1234.com/archives/2015/07/363.htm Spark算子:RDD基本转换操作(1)–map.flagMap.distinct Spark算子:RDD创建操 ...

随机推荐

  1. 动态代理实现AOP

    代理 代理顾名思义:代为处理.不是对目标对象的直接操作,而是通过代理对目标对象进行包装,此时可以在目标对象的基础上添加额外的操作以满足业务需求.图示 分类:动态代理.静态代理. 代理三要素:共同接口. ...

  2. java 学习基础知识点拾遗 导航页

    每种编程语言的知识点都是很多很杂的,java也是如此 相信很多人学习的过程中都是深一脚浅一脚,最基础的东西可能有些也不是非常确定 整理了最基本的一些知识点,可以说是java入门的-1层级别的,作为自己 ...

  3. go等待N个线程完成操作总结

    第一种,基于原生带缓存的channel package main import "fmt" func main() { done := make(chan int, 10) for ...

  4. 使用ZeroBrane Studio调试Openresty lua脚本

    介绍 ZeroBraneStudio 作为轻量级.跨平台的Lua IDE,已被广泛用来调试各种Lua引擎游戏框架.Openresty.Wireshark脚本等等. Openresty 是一个建立在Ng ...

  5. Perl的子程序

    子程序(subroutine) perl中的子程序其实就是自定义函数.它使用sub关键字开头,表示声明一个子程序 子程序名称有独立的名称空间,不会和其它名称冲突 Perl中的子程序中可以定义.引用.修 ...

  6. go基础系列:数组

    了解Python.Perl.JavaScript的人想必都知道它们的数组是动态的,可以随需求自动增大数组长度.但Go中的数组是固定长度的,数组一经声明,就无法扩大.缩减数组的长度.但Go中也有类似的动 ...

  7. 爬虫之抓取js生成的数据

    有很多页面,当我们用request发送请求,返回的内容里面并没有页面上显示的数据,主要有两种情况,一是通过ajax异步发送请求,得到响应把数据放入页面中,对于这种情况,我们可以查看关于ajax的请求, ...

  8. NLP入门(四)命名实体识别(NER)

      本文将会简单介绍自然语言处理(NLP)中的命名实体识别(NER).   命名实体识别(Named Entity Recognition,简称NER)是信息提取.问答系统.句法分析.机器翻译等应用领 ...

  9. Javascript 定时器调用传递参数的方法

    文章来源:  https://m.jb51.net/article/20880.htm 备注:先记下,以后整理: Javascript 定时器调用传递参数的方法,需要的朋友可以参考下. 无论是wind ...

  10. .NET使用ServerManager获取网站物理路径

    最近因为工作需要,用wpf做了一个辅助小工具,如下图 为了获取网站的物理路径,我分析了通过ServerManager获取到的变量,也通过百度搜索了很多,但仍然没有找到方法. 后来使用必应,在国外网站找 ...