Spark Streaming有状态转换之updateStateByKey的使用

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

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

updateStateByKey的功能

  • 对相同的key继续聚合,updateStateByKey可以跨批次处理数据,可以聚合之前周期的所有数据。比如累加wordcount。

代码

  • 状态信息保存在checkpoint目录中,需要指定checkpoint目录。
  • 聚合后需要更新状态信息。
  def main(args: Array[String]): Unit = {
    val conf: SparkConf = new SparkConf().setAppName(this.getClass.getSimpleName).setMaster("local[*]")
    val ssc = new StreamingContext(conf,Seconds(3))
    //指定checkpoint目录
    ssc.checkpoint("D:\\develop\\workspace\\bigdata2021\\spark2021\\checkpoint")
    //接收数据
    val dataDStream: ReceiverInputDStream[String] = ssc.socketTextStream("hadoop01", 8888)
    //处理数据
    val mapDStream: DStream[(String, Int)] = dataDStream.flatMap(_.split(" ")).map((_,1))
    //累加之前周期的数据
    val resDStream: DStream[(String, Int)] = mapDStream.updateStateByKey(
      //参数1:当前周期中相同的key对应的value的集合
      //参数2:之前周期中相同的key的聚合结果
      (seq: Seq[Int], state: Option[Int]) => {
        //当前周期的value和之前周期的value聚合
        val count: Int = seq.sum + state.getOrElse(0)
        //结果放入缓冲区,更新状态信息
        Option(count)
      }
    )
    resDStream.print()

    //开启采集
    ssc.start()
    //等待采集结束
    ssc.awaitTermination()
  }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值