博客
关于我
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/

    你可能感兴趣的文章
    Net操作配置文件(Web.config|App.config)通用类
    查看>>
    Neutron系列 : Neutron OVS OpenFlow 流表 和 L2 Population(7)
    查看>>
    New Relic——手机应用app开发达人的福利立即就到啦!
    查看>>
    NFinal学习笔记 02—NFinalBuild
    查看>>
    NFS
    查看>>
    NFS Server及Client配置与挂载详解
    查看>>
    NFS共享文件系统搭建
    查看>>
    nfs复习
    查看>>
    NFS安装配置
    查看>>
    NFS的安装以及windows/linux挂载linux网络文件系统NFS
    查看>>
    NFS的常用挂载参数
    查看>>
    NFS网络文件系统
    查看>>
    nft文件传输_利用remoting实现文件传输-.NET教程,远程及网络应用
    查看>>
    NFV商用可行新华三vBRAS方案实践验证
    查看>>
    ng build --aot --prod生成文件报错
    查看>>
    ng 指令的自定义、使用
    查看>>
    nghttp3使用指南
    查看>>
    Nginx
    查看>>
    nginx + etcd 动态负载均衡实践(三)—— 基于nginx-upsync-module实现
    查看>>
    nginx + etcd 动态负载均衡实践(二)—— 组件安装
    查看>>