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

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

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

window的功能

  • 可以跨批次处理窗口内的数据。
  • 用于监控某个时间段内数据流量的变化。

代码

  • window使用需要指定窗口大小和步长。
  • 窗口大小和步长只能时采集周期的整数倍。
  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)
    //设置窗口大小和滑动步长
    val windowDStream: DStream[String] = dataDStream.window(Seconds(6),Seconds(3))
    //处理数据
    val resDStream: DStream[(String, Int)] = windowDStream.flatMap(_.split(" ")).map((_,1)).reduceByKey(_+_)

    resDStream.print()
    //开启采集
    ssc.start()
    ssc.awaitTermination()

  }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值