spark的血脉机制

第一个问题:软件在设计时是怎么保证数据的安全性?

方案一:副本机制:将数据存储多份,每一份存在不同的节点上【内存一般不建议使用副本,内存小,而且易丢失】 hdfs

方案二:操作日志:记录内存的所有变化追加到一个日志文件中,可以通过日志文件进行恢复【日志数据量太大,恢复部分数据性能特别差】 namenode、redis

方案三:依赖关系:记录所有数据的来源,当数据丢失的时候,基于数据来源重新构建一份 spark

Spark的血缘机制(Lineage)是其容错设计的核心,通过记录数据转换的依赖关系而非存储中间数据实现高效容错。其运作机制如下:

一、血缘机制原理

  1. 依赖关系记录

    每个RDD(弹性分布式数据集)存储其生成逻辑: $$ \text{RDD}\text{new} = f(\text{RDD} \text{parent}) $$ 例如:textRDD = fileRDD.flatMap(lambda line: line.split(" "))

  2. 有向无环图(DAG)

    所有转换操作构成依赖关系图:

    复制代码
    graph LR
    A[原始RDD] --> B[Map操作]
    B --> C[Filter操作]
    C --> D[最终RDD]

二、容错实现流程

当节点故障导致分区丢失时:

  1. 回溯依赖链
    根据血缘记录定位数据源头
  2. 重新计算
    仅重算丢失分区的转换路径

    \\text{恢复时间} \\propto \\text{依赖链长度}

三、技术优势

  1. 空间高效
    避免数据复制,节省存储成本
  2. 计算优化
    支持检查点(Checkpoint)缩短依赖链

    T_\\text{recovery} = \\min(T_\\text{full_compute}, T_\\text{checkpoint})

案例 :过滤大文件时仅需记录filter(func)的转换逻辑,故障后直接从源文件重新执行过滤,无需备份中间数据。

相关推荐
字节跳动数据平台16 小时前
代码量减少 70%、GPU 利用率达 95%:火山引擎多模态数据湖如何释放模思智能的算法生产力
大数据
得物技术18 小时前
深入剖析Spark UI界面:参数与界面详解|得物技术
大数据·后端·spark
武子康19 小时前
大数据-238 离线数仓 - 广告业务 Hive分析实战:ADS 点击率、购买率与 Top100 排名避坑
大数据·后端·apache hive
武子康2 天前
大数据-237 离线数仓 - Hive 广告业务实战:ODS→DWD 事件解析、广告明细与转化分析落地
大数据·后端·apache hive
大大大大晴天2 天前
Flink生产问题排障-Kryo serializer scala extensions are not available
大数据·flink
武子康4 天前
大数据-236 离线数仓 - 会员指标验证、DataX 导出与广告业务 ODS/DWD/ADS 全流程
大数据·后端·apache hive
肌肉娃子4 天前
20260227.spark.Spark 性能刺客:千万别在 for 循环里写 withColumn
spark
初次攀爬者5 天前
ZooKeeper 实现分布式锁的两种方式
分布式·后端·zookeeper
武子康5 天前
大数据-235 离线数仓 - 实战:Flume+HDFS+Hive 搭建 ODS/DWD/DWS/ADS 会员分析链路
大数据·后端·apache hive
DianSan_ERP5 天前
电商API接口全链路监控:构建坚不可摧的线上运维防线
大数据·运维·网络·人工智能·git·servlet