博客
关于我
Spark初识 --- spark-core Rdd的创建及分类
阅读量:316 次
发布时间:2019-03-04

本文共 1150 字,大约阅读时间需要 3 分钟。

Spark 的初识与 RDD 基础

Spark 是一个强大的并行计算框架,能够处理大规模数据的复杂计算任务。作为 Spark 的核心,Resilient Distributed Dataset(RDD)是 Spark 提供的数据处理与计算的基础。

Spark 与 Hadoop 的历史回顾

Spark 并不是第一个大数据处理框架,它的前身可以追溯到 Hadoop。Hadoop 在早期的大数据处理中以其分布式处理能力和容错机制而闻名。然而,随着大数据应用的快速发展,Spark 因其高效的并行模型和内存优化而逐渐成为主流。

Spark 框架与 Hadoop 的对比

与 Hadoop 相比,Spark 的主要优势在于其内存处理能力和更高效的并行模型。Spark 提供了更加灵活和便捷的API,适合处理多种类型的数据和复杂的分析任务。

RDD 的核心特点

RDD 可以看作是 Spark 的数据容器,具有以下特点:

  • 弹性分布式数据集:RDD 是一种虚拟数据集,它只是对数据文件的引用,而不是实际的数据复制。Spark 会根据需要动态分配数据块。

  • 内存优化:Spark 的 RDD 通常运行在内存中,这使得数据访问速度显著提升,适合需要频繁读写的场景。

  • 编程模型:RDD 提供了一个高级的编程模型,支持函数化编程和惰性求值(Lazy Evaluation),这使得大规模数据处理更加高效。

  • RDD 的创建方式

  • 本地数据集:通过 parallelizemakeRDD 方法创建 RDD。parallelize 可以为 RDD 指定分区数,而 makeRDD 则会根据数据文件自动确定分区。

  • 外部数据集:通过 textFile 或其他读取外部存储(如 HDFS)的方法创建 RDD。这种方法会根据文件的存储结构自动划分分区。

  • 衍生 RDD:通过对现有 RDD 进行操作(如 mapreduce 等)创建新的 RDD。新生成的 RDD 与原 RDD 是独立的。

  • RDD 的分类与操作

    RDD 支持多种数据类型和操作类型:

  • 基础类型数据:如 Int、String 等,适用于结构化数据处理。

  • 键值数据:通过 PairRDD 类处理键值对数据。

  • 数值数据:提供了专门的算子来处理高性能计算任务。

  • RDD 的惰性求值机制

    Spark 的惰性求值机制(Lazy Evaluation)是其核心优势之一。所有 Transformation 操作不会立即执行,而是记录在 RDD 上。当需要结果时,才会触发相应的 Task 执行。这大大减少了资源浪费,提升了处理效率。

    通过以上内容可以看出,Spark 的 RDD 模型为大数据处理提供了强大的工具。理解 RDD 的特点和操作方式,是掌握 Spark 技术的基础。

    转载地址:http://mrhq.baihongyu.com/

    你可能感兴趣的文章
    oracle深度解析检查点
    查看>>
    Oracle游标
    查看>>
    oracle游标数最大数,Oracle 最大连接数 最大游标数
    查看>>
    oracle用户改名
    查看>>
    oracle用户解压不了,PLSQL developer 连接不上64位Oracle 的解决方法
    查看>>
    oracle用户解锁
    查看>>
    Oracle用游标删除重复数据
    查看>>
    Tomcat学习总结(19)—— 为什么首选Tomcat作为JavaWeb应用服务器?
    查看>>
    oracle的内置函数
    查看>>
    Oracle的存储结构
    查看>>
    Oracle的聚合函数group by结合CUBE和ROLLUP的使用
    查看>>
    Oracle监听配置、数据库实例配置等
    查看>>
    Oracle笔记(十三) 视图、同义词、索引
    查看>>
    Oracle笔记(十) 约束
    查看>>
    Oracle系列:安装Oracle RAC数据库(二)
    查看>>
    oracle系统 介绍,ORACLE数据库管理系统介绍
    查看>>
    oracle获取数据库表、字段、注释、约束等
    查看>>
    oracle表空间查询维护命令大全之三(暂时表空间)史上最全
    查看>>
    oracle表访问方式
    查看>>
    Oracle触发器
    查看>>