Spark Streaming无状态转换操作之transform的使用

本文介绍了SparkStreaming中的有状态转换和无状态转换概念。有状态转换允许对不同批次的数据进行处理,例如统计词频,而无状态转换只处理当前批次数据,不涉及历史数据。示例代码展示了如何使用transform函数进行有状态的词频统计。

有状态转换和无状态转换的区别

  • Spark Streaming中,如果该操作可以同时对不同批次的数据进行处理,就是有状态转换。如果该操作只能对每个批次中的数据依次进行处理,不同批次之间的数据不进行运算,就是无状态转换。

transform功能

  • 可以对每个批次中的DStream封装的RDD进行操作,可以直接使用RDD的算子。

代码

  def main(args: Array[String]): Unit = {
    val conf: SparkConf = new SparkConf().setAppName(this.getClass.getSimpleName).setMaster("local[*]")
    val ssc = new StreamingContext(conf, Seconds(3))

    //接收数据
    val dataDStream: ReceiverInputDStream[String] = ssc.socketTextStream("hadoop01",8888)
    //transform处理DStream每个批次中的RDD
    val resDStream: DStream[(String, Int)] = dataDStream.transform(
      rdd => {
        //统计词频并排序
        rdd.flatMap(_.split(" ")).map((_, 1)).reduceByKey(_ + _).sortBy(_._2)
      }
    )
    resDStream.print()

    //开启采集
    ssc.start()
    //等待采集完成
    ssc.awaitTermination()

  }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值