Spark Stream

一、Spark Streaming是什么

Spark Streaming 用于流式数据的处理。Spark Streaming 支持的数据输入源很多,例如:Kafka、Flume、Twitter、ZeroMQ 和简单的 TCP 套接字等等。数据输入后可以用 Spark 的高度抽象原语如:map、reduce、join、window 等进行运算。而结果也能保存在很多地方,如 HDFS,数据库等

Spark Streaming 是 Spark Core 的扩展,它支持高吞吐量、可容错的实时数据流处理。在 Spark Streaming 中,数据被切分为一系列连续的批处理,每个批处理被当作一个 RDD。

二、Spark Streaming的特点

1.易用、2.容错、3.易整合到Spark体系

三、Spark Streaming 常用的 API

  1. StreamingContext: 这是 Spark Streaming 的主要入口点,用于创建和配置流式计算。

    scala 复制代码
  2. textFileStream(directory): 从指定目录中读取新文件作为数据源。

    scala 复制代码
  3. queueStream(rddQueue): 从给定的RDD队列中获取数据。

    scala 复制代码
  4. socketTextStream(hostname, port): 从指定主机名和端口上的TCP套接字接收数据。

    scala 复制代码
  5. receiverStream(blockReceiver): 使用自定义的BlockReceiver来接收数据。

    scala 复制代码
  6. fileStream(directory): 监视指定目录下的新文件,与textFileStream类似,但可以设置检查间隔和滚动时间间隔。

    scala 复制代码
  7. foreachRDD(func): 对每个RDD执行操作,通常用于将数据写入外部系统或进行复杂的批处理操作。

    scala 复制代码
  8. count(): 返回每个批次中的元素数量。

    scala 复制代码
  9. reduce(func): 使用给定的函数将所有元素聚合成一个值。

    scala 复制代码
  10. collect(): 将数据收集到驱动程序节点上。

    scala 复制代码
  11. updateStateByKey(func): 根据键值更新状态。

    scala 复制代码
  12. mapWithState(func): 使用给定的函数和状态映射RDD。

    scala 复制代码
  13. window(windowLength, slideInterval): 创建一个滑动窗口。

    scala 复制代码
  14. reduceByWindow(func, windowLength, slideInterval): 在给定的窗口长度和滑动间隔内进行归约操作。

    scala 复制代码
  15. transform(rddFunc, outputMode): 使用给定的RDD函数转换输入RDD。

    scala 复制代码
  16. union(otherStream): 合并两个DStream。

    scala 复制代码
  17. intersection(otherStream): 计算两个DStream的交集。

    scala 复制代码
  18. subtract(otherStream): 计算两个DStream的差集。

    scala 复制代码
  19. join(otherStream): 连接两个DStream。

    scala 复制代码
  20. filter(func): 过滤DStream中的元素。

    scala 复制代码
  21. flatMap(func): 扁平化DStream中的元素。

    scala 复制代码
  22. map(func): 映射DStream中的元素。

    scala 复制代码
  23. foreachRDD(func): 对每个RDD执行操作,但不返回结果。

    scala 复制代码
  24. start(): 启动流式计算。

    scala 复制代码
  25. awaitTermination(): 等待流式计算终止。

    scala 复制代码

这些 API 提供了强大的功能,使 Spark Streaming 能够处理各种实时数据流任务。

相关推荐
武子康18 小时前
大数据-236 离线数仓 - 会员指标验证、DataX 导出与广告业务 ODS/DWD/ADS 全流程
大数据·后端·apache hive
肌肉娃子1 天前
20260227.spark.Spark 性能刺客:千万别在 for 循环里写 withColumn
spark
初次攀爬者2 天前
ZooKeeper 实现分布式锁的两种方式
分布式·后端·zookeeper
武子康2 天前
大数据-235 离线数仓 - 实战:Flume+HDFS+Hive 搭建 ODS/DWD/DWS/ADS 会员分析链路
大数据·后端·apache hive
DianSan_ERP2 天前
电商API接口全链路监控:构建坚不可摧的线上运维防线
大数据·运维·网络·人工智能·git·servlet
够快云库2 天前
能源行业非结构化数据治理实战:从数据沼泽到智能资产
大数据·人工智能·机器学习·企业文件安全
AI周红伟2 天前
周红伟:智能体全栈构建实操:OpenClaw部署+Agent Skills+Seedance+RAG从入门到实战
大数据·人工智能·大模型·智能体
B站计算机毕业设计超人2 天前
计算机毕业设计Django+Vue.js高考推荐系统 高考可视化 大数据毕业设计(源码+LW文档+PPT+详细讲解)
大数据·vue.js·hadoop·django·毕业设计·课程设计·推荐算法
计算机程序猿学长2 天前
大数据毕业设计-基于django的音乐网站数据分析管理系统的设计与实现(源码+LW+部署文档+全bao+远程调试+代码讲解等)
大数据·django·课程设计
B站计算机毕业设计超人2 天前
计算机毕业设计Django+Vue.js音乐推荐系统 音乐可视化 大数据毕业设计 (源码+文档+PPT+讲解)
大数据·vue.js·hadoop·python·spark·django·课程设计