Flink:按键状态流处理

Flink: Stateful stream processing by key

我有数据流,例如 JSON 带有 ID 的记录。

我想处理数据,使具有相同键的所有记录都由相同的有状态任务处理。

我该怎么做?

这可以通过 KeyedStream 上的有状态运算符来完成。 A KeyedStream 对键上的所有记录进行分区,并确保具有相同键的所有记录都进入相同的运算符实例并与相同的状态交互。

代码如下:

val stream: DataStream[(String, Long)] = ???
val sumByKey: DataStream[(String, Long)] = stream
  .keyBy(_._1) // key on the first attribute
  .map(new SumMapper())

class SumMapper extends RichMapFunction[(String, Long), (String, Long)] {

  var sumState: ValueState[Long] = _

  override def open(config: Configuration) {
    // configure state
    val sumDesc: ValueStateDescriptor[Long] =
      new ValueStateDescriptor[Long]("sum", classOf[Long])
    sumState = getRuntimeContext.getState(sumDesc)
  }

  override def map(in: (String, Long)): (String, Long) = {
    val sum = sumState.value() // get current sum from state
    val newSum = sum + in._2   // compute new sum
    sumState.update(newSum)    // update state
    (in._1, newSum)            // emit result
  }
}