Spark Programming by Java——RDD基本操作

2024-06-14 22:08

本文主要是介绍Spark Programming by Java——RDD基本操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在一个内容为{1, 2, 3, 3}的RDD上进行的基本操作

函数名(表现形式为scala)目的示例结果
collect()返回RDD中的所有元素rdd.example(){1, 2, 3, 4}
count()RDD中的元素数目rdd.count()4
countByValue()RDD中每个元素的出现次数rdd.countByValue(){(1,1),(2,1),(3,2)}
take(num)返回RDD中num个数量的元素rdd.take(2){1,2}
top(num)返回RDD中最大的num个元素rdd.top(2){3,3}
takeOrdered(num)(ordering)根据你给的排序方法返回一个元素序列rdd.takeOrdered(2)(myOrdering){3, 3}
takeSample(withReplacement, num, [speed])随机返回num个元素rdd.takeSample(false, 1)无值
reduce(func)在一次遍历中合并RDD中所有的元素(例如,求和)rdd.reduce((x, y) => x + y)9
fold(zero)(func)和reduce功能一样,但是提供一个初值rdd.fold(0)((x, y) => x + y)9
aggregate(zeroValue)(seqOp, comOp)和reduce()函数类似,但是用于返回不同的数据类型rdd.aggregate((0, 0)) ((x, y) =>(x._1 + y, x._2 + 1), (x, y) =>(x._1 + y._1, x._2 + y._2))(9,4)
foreach(func)将RDD中所有的元素都用于提供的方法rdd.foreach(func)nothing


Java实现基本代码

import java.util.Arrays;
import java.util.List;import org.apache.spark.SparkConf;
import org.apache.spark.api.java.JavaRDD;
import org.apache.spark.api.java.JavaSparkContext;
import org.apache.spark.api.java.function.Function2;
import org.apache.spark.api.java.function.VoidFunction;public class SimpleRDD {public static void main(String[] args) {SparkConf conf = new SparkConf().setMaster("local").setAppName("SimpleRDD");JavaSparkContext sc = new JavaSparkContext(conf);JavaRDD<Integer> rdd = sc.parallelize(Arrays.asList(1, 2, 3 ,3), 2);System.out.println("rdd collect" + rdd.collect());System.out.println("rdd count" + rdd.count());System.out.println("rdd countByValue" + rdd.countByValue());System.out.println("rdd take" + rdd.take(2));System.out.println("rdd top" + rdd.top(2));System.out.println("rdd takeOrdered" + rdd.takeOrdered(2));System.out.println("rdd reduce" + rdd.reduce((x, y) -> x + y));System.out.println("rdd fold" + rdd.fold(0, (x, y) -> x+y));System.out.println("rdd aggregate test");List<Integer> data = Arrays.asList(5, 1, 1, 4, 4, 2, 2);JavaRDD<Integer> javaRDD = sc.parallelize(data, 2);Integer aggregateValue = javaRDD.aggregate(3, new Function2<Integer, Integer, Integer>() {    @Override    public Integer call(Integer v1, Integer v2) throws Exception {        System.out.println("seq~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~" + v1 + "," + v2);        return Math.max(v1, v2);    }}, new Function2<Integer, Integer, Integer>() {    int i = 0;    @Override      public Integer call(Integer v1, Integer v2) throws Exception {    System.out.println("comb~~~~~~~~~i~~~~~~~~~~~~~~~~~~~"+i++);        System.out.println("comb~~~~~~~~~v1~~~~~~~~~~~~~~~~~~~" + v1);        System.out.println("comb~~~~~~~~~v2~~~~~~~~~~~~~~~~~~~" + v2);        return v1 + v2;   }});System.out.println("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"+aggregateValue);System.out.println("foreach");rdd.foreach(new VoidFunction<Integer>() {@Overridepublic void call(Integer t) throws Exception {System.out.println(t);}});}
}

这篇关于Spark Programming by Java——RDD基本操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1061631

相关文章

SpringBoot中SM2公钥加密、私钥解密的实现示例详解

《SpringBoot中SM2公钥加密、私钥解密的实现示例详解》本文介绍了如何在SpringBoot项目中实现SM2公钥加密和私钥解密的功能,通过使用Hutool库和BouncyCastle依赖,简化... 目录一、前言1、加密信息(示例)2、加密结果(示例)二、实现代码1、yml文件配置2、创建SM2工具

Spring WebFlux 与 WebClient 使用指南及最佳实践

《SpringWebFlux与WebClient使用指南及最佳实践》WebClient是SpringWebFlux模块提供的非阻塞、响应式HTTP客户端,基于ProjectReactor实现,... 目录Spring WebFlux 与 WebClient 使用指南1. WebClient 概述2. 核心依

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

java中新生代和老生代的关系说明

《java中新生代和老生代的关系说明》:本文主要介绍java中新生代和老生代的关系说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、内存区域划分新生代老年代二、对象生命周期与晋升流程三、新生代与老年代的协作机制1. 跨代引用处理2. 动态年龄判定3. 空间分

Java设计模式---迭代器模式(Iterator)解读

《Java设计模式---迭代器模式(Iterator)解读》:本文主要介绍Java设计模式---迭代器模式(Iterator),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录1、迭代器(Iterator)1.1、结构1.2、常用方法1.3、本质1、解耦集合与遍历逻辑2、统一

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空