有这样需求,统计每个小时,一个线路被点击次数,
需要每30秒统计一次写入redis,采用Slide窗口滑动,但发现一个问题,当key没有新的消息消费,
当(key,value)的value不变的,滑动统计还是会输出统计值,这个key的value就没必须要写入redis。
所以采用ValueState的update更新,
代码如下:
DataStream<Tuple2<String, Integer>> result = exposure.map(new MapFunction<PlanDetailBO, Tuple2<String, Integer>>() {
@Override
public Tuple2<String, Integer> map(PlanDetailBO value) throws Exception {
String durationData = value.getFirstFromDate();
String firstTrafficCode = value.getFirstNo();
String secondTrafficCode = value.getSecondNo();
String startStationCode = value.getFirstFromStationCode();
String transferArriveStationCode = value.getFirstToStationCode();
String transferLeaveStationCode =