Flink之sideoutputStream

Flink之sideoutputStream

侧输出流可以解决split过时的问题,将不同类别的数据分开成2个流「

stream.process(ProcessFunction(

if() out.collect

else cox.output(new OutputLag(“id”))

))

主数据通过out.collect()进行输出

侧输出数据通过 ctx.output()进行输出

通过主数据流.getSideOutput(“sideoutput id”)获取侧输出流

示例代码:

package com.shufang.flink.functions

import com.shufang.flink.bean.SensorReading
import org.apache.flink.streaming.api.TimeCharacteristic
import org.apache.flink.streaming.api.functions.ProcessFunction
import org.apache.flink.streaming.api.functions.timestamps.BoundedOutOfOrdernessTimestampExtractor
import org.apache.flink.streaming.api.scala._
import org.apache.flink.streaming.api.windowing.time.Time
import org.apache.flink.util.Collector

object SideOutputDemo {
  def main(args: Array[String]): Unit = {

    val env: StreamExecutionEnvironment = StreamExecutionEnvironment.getExecutionEnvironment
    env.setParallelism(1)
    env.setStreamTimeCharacteristic(TimeCharacteristic.EventTime)

    val inputStream: DataStream[SensorReading] = env.socketTextStream("localhost", 9999).map(
      line => {
        val strings: Array[String] = line.split(",")
        SensorReading(strings(0), strings(1).trim.toLong, strings(2).trim.toDouble)
      }
    ).assignTimestampsAndWatermarks(new BoundedOutOfOrdernessTimestampExtractor[SensorReading](Time.seconds(1)) {
      override def extractTimestamp(element: SensorReading): Long = {
        element.timeStamp
      }
    })


    // 处理后得到的是主流
    val mainStream: DataStream[SensorReading] = inputStream.process(new ColdFunction())

    // 通过主流得到侧输出流
    val sideStream: DataStream[String] = mainStream.getSideOutput(new OutputTag[String]("cold flag"))


    mainStream.print("主流")
    sideStream.print("侧输出流")
    env.execute()
  }
}

class ColdFunction() extends ProcessFunction[SensorReading, SensorReading] {

  private lazy val outputlag = new OutputTag[String]("cold flag")

  override def processElement(
                               value: SensorReading,
                               ctx: ProcessFunction[SensorReading, SensorReading]#Context,
                               out: Collector[SensorReading]): Unit = {
    if (value.temperture < 30) {
      ctx.output(outputlag, "cold报警" +value.id+"\t"+ value.temperture)
    }else{
      out.collect(value)
    }
  }
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值